From b2203611428c4d3b46a2c3818d389a7d7e5f4a34 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Wed, 7 Oct 2020 19:06:07 +0300 Subject: [PATCH 01/73] Added password reset tutorial to FAQ --- docs/content/FAQ/_index.md | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/docs/content/FAQ/_index.md b/docs/content/FAQ/_index.md index 258cd4c0a..85e751259 100644 --- a/docs/content/FAQ/_index.md +++ b/docs/content/FAQ/_index.md @@ -9,6 +9,7 @@ Here are some of the most common questions we receive about the Infection Monkey - [Where can I get the latest Monkey version? 📰](#where-can-i-get-the-latest-monkey-version) - [How long does a single Monkey run for? Is there a time limit?](#how-long-does-a-single-monkey-run-for-is-there-a-time-limit) +- [How to reset the password?](#how-to-reset-the-password) - [Should I run the Monkey continuously?](#should-i-run-the-monkey-continuously) - [Which queries does Monkey perform to the Internet exactly?](#which-queries-does-monkey-perform-to-the-internet-exactly) - [Where can I find the log files of the Monkey and the Monkey Island, and how can I read them?](#where-can-i-find-the-log-files-of-the-monkey-and-the-monkey-island-and-how-can-i-read-them) @@ -35,6 +36,23 @@ If you want to see what has changed between versions, refer to the [releases pag The Monkey shuts off either when it can't find new victims, or when it has exceeded the quota of victims as defined in the configuration. +## How to reset the password? + +On your first access of Monkey Island server, you'll be prompted to create an account. If you forgot the credentials you + entered or just want to change them, you need to manually alter the `server_config.json` file. On Linux, this file is + located on `/var/monkey/monkey_island/cc/server_config.json`. On windows, it's based on your install directory (typically + `C:\Program Files\Guardicore\Monkey Island\monkey_island\cc\server_config.json`). Reset the contents of this file back to + +```json +{ + "server_config": "password", + "deployment": "windows" +} +``` +Leave the deployment option unchanged (it might be "vmware" or "linux" in your case). Then reset the Island process +(`sudo systemctl restart monkey-island.service` for linux, restart program for windows). Go to the island's URL and create +a new account. + ## Should I run the Monkey continuously? Yes! This will allow you to verify that no new security issues were identified by the Monkey since the last time you ran it. From a9af6fe7366dfdbc33f28e0ebe50a48e11e1d055 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Mon, 12 Oct 2020 16:54:38 +0300 Subject: [PATCH 02/73] Refactored tornado into gevent for non-blocking server --- monkey/monkey_island.py | 3 +++ monkey/monkey_island/cc/main.py | 14 ++++++-------- .../cc/services/infection_lifecycle.py | 4 ++-- .../reporting/report_generation_synchronisation.py | 8 ++++---- monkey/monkey_island/cc/ui/webpack.config.js | 3 ++- monkey/monkey_island/requirements.txt | 2 +- 6 files changed, 18 insertions(+), 16 deletions(-) diff --git a/monkey/monkey_island.py b/monkey/monkey_island.py index b3b74e6b3..c3549333f 100644 --- a/monkey/monkey_island.py +++ b/monkey/monkey_island.py @@ -1,3 +1,6 @@ +from gevent import monkey +monkey.patch_all() + from monkey_island.cc.main import main diff --git a/monkey/monkey_island/cc/main.py b/monkey/monkey_island/cc/main.py index 610681034..cf58f48c5 100644 --- a/monkey/monkey_island/cc/main.py +++ b/monkey/monkey_island/cc/main.py @@ -6,6 +6,8 @@ from pathlib import Path from threading import Thread # Add the monkey_island directory to the path, to make sure imports that don't start with "monkey_island." work. +from gevent.pywsgi import WSGIServer + MONKEY_ISLAND_DIR_BASE_PATH = str(Path(__file__).parent.parent) if str(MONKEY_ISLAND_DIR_BASE_PATH) not in sys.path: sys.path.insert(0, MONKEY_ISLAND_DIR_BASE_PATH) @@ -46,9 +48,6 @@ def main(should_setup_only=False): def start_island_server(should_setup_only): - from tornado.httpserver import HTTPServer - from tornado.ioloop import IOLoop - from tornado.wsgi import WSGIContainer mongo_url = os.environ.get('MONGO_URL', env_singleton.env.get_mongo_url()) wait_for_mongo_db_server(mongo_url) @@ -69,12 +68,11 @@ def start_island_server(should_setup_only): if env_singleton.env.is_debug(): app.run(host='0.0.0.0', debug=True, ssl_context=(crt_path, key_path)) else: - http_server = HTTPServer(WSGIContainer(app), - ssl_options={'certfile': os.environ.get('SERVER_CRT', crt_path), - 'keyfile': os.environ.get('SERVER_KEY', key_path)}) - http_server.listen(env_singleton.env.get_island_port()) + http_server = WSGIServer(('0.0.0.0', env_singleton.env.get_island_port()), app, + certfile=os.environ.get('SERVER_CRT', crt_path), + keyfile=os.environ.get('SERVER_KEY', key_path)) log_init_info() - IOLoop.instance().start() + http_server.serve_forever() def log_init_info(): diff --git a/monkey/monkey_island/cc/services/infection_lifecycle.py b/monkey/monkey_island/cc/services/infection_lifecycle.py index f29b9ba71..298db3e25 100644 --- a/monkey/monkey_island/cc/services/infection_lifecycle.py +++ b/monkey/monkey_island/cc/services/infection_lifecycle.py @@ -8,8 +8,8 @@ from monkey_island.cc.resources.test.utils.telem_store import TestTelemStore from monkey_island.cc.services.config import ConfigService from monkey_island.cc.services.node import NodeService from monkey_island.cc.services.reporting.report import ReportService -from monkey_island.cc.services.reporting.report_generation_synchronisation import ( - is_report_being_generated, safe_generate_reports) +from monkey_island.cc.services.reporting.report_generation_synchronisation import safe_generate_reports, \ + is_report_being_generated logger = logging.getLogger(__name__) diff --git a/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py b/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py index f2fa11c89..803ecc75c 100644 --- a/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py +++ b/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py @@ -1,5 +1,5 @@ import logging -import threading +from gevent.lock import Semaphore logger = logging.getLogger(__name__) @@ -7,9 +7,9 @@ logger = logging.getLogger(__name__) # Report generation can be quite slow if there is a lot of data, and the UI queries the Root service often; without # the locks, these requests would accumulate, overload the server, eventually causing it to crash. logger.debug("Initializing report generation locks.") -__report_generating_lock = threading.Semaphore() -__attack_report_generating_lock = threading.Semaphore() -__regular_report_generating_lock = threading.Semaphore() +__report_generating_lock = Semaphore() +__attack_report_generating_lock = Semaphore() +__regular_report_generating_lock = Semaphore() def safe_generate_reports(): diff --git a/monkey/monkey_island/cc/ui/webpack.config.js b/monkey/monkey_island/cc/ui/webpack.config.js index 08c2a77f3..79d455344 100644 --- a/monkey/monkey_island/cc/ui/webpack.config.js +++ b/monkey/monkey_island/cc/ui/webpack.config.js @@ -74,7 +74,8 @@ module.exports = { proxy: { '/api': { target: 'https://localhost:5000', - secure: false + secure: false, + changeOrigin: true } } } diff --git a/monkey/monkey_island/requirements.txt b/monkey/monkey_island/requirements.txt index 7e7272a87..894b87647 100644 --- a/monkey/monkey_island/requirements.txt +++ b/monkey/monkey_island/requirements.txt @@ -8,6 +8,7 @@ botocore==1.17.54 cffi>=1.8,!=1.11.3 dpath>=2.0 flask>=1.1 +gevent>=20.9.0 ipaddress>=1.0.23 jsonschema==3.2.0 mongoengine>=0.20 @@ -20,7 +21,6 @@ requests>=2.24 ring>=0.7.3 stix2>=2.0.2 six>=1.13.0 -tornado>=6.0.4 tqdm>=4.47 virtualenv>=20.0.26 werkzeug>=1.0.1 From f2b65ecf14df53dc4c2aad2a9332a20a963f9cb4 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Thu, 15 Oct 2020 13:02:12 +0300 Subject: [PATCH 03/73] Improved gevent related code by using BoundedSemaphore instead of Semaphore and other small style fixes --- monkey/monkey_island.py | 9 +++++---- .../reporting/report_generation_synchronisation.py | 8 ++++---- 2 files changed, 9 insertions(+), 8 deletions(-) diff --git a/monkey/monkey_island.py b/monkey/monkey_island.py index c3549333f..44b347e8c 100644 --- a/monkey/monkey_island.py +++ b/monkey/monkey_island.py @@ -1,5 +1,5 @@ -from gevent import monkey -monkey.patch_all() +from gevent import monkey as gevent_monkey +gevent_monkey.patch_all() from monkey_island.cc.main import main @@ -8,8 +8,9 @@ def parse_cli_args(): import argparse parser = argparse.ArgumentParser(description="Infection Monkey Island CnC Server. See https://infectionmonkey.com") parser.add_argument("-s", "--setup-only", action="store_true", - help="Pass this flag to cause the Island to setup and exit without actually starting. This is useful " - "for preparing Island to boot faster later-on, so for compiling/packaging Islands.") + help="Pass this flag to cause the Island to setup and exit without actually starting. " + "This is useful for preparing Island to boot faster later-on, so for " + "compiling/packaging Islands.") args = parser.parse_args() return args.setup_only diff --git a/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py b/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py index 803ecc75c..944989b53 100644 --- a/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py +++ b/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py @@ -1,5 +1,5 @@ import logging -from gevent.lock import Semaphore +from gevent.lock import BoundedSemaphore logger = logging.getLogger(__name__) @@ -7,9 +7,9 @@ logger = logging.getLogger(__name__) # Report generation can be quite slow if there is a lot of data, and the UI queries the Root service often; without # the locks, these requests would accumulate, overload the server, eventually causing it to crash. logger.debug("Initializing report generation locks.") -__report_generating_lock = Semaphore() -__attack_report_generating_lock = Semaphore() -__regular_report_generating_lock = Semaphore() +__report_generating_lock = BoundedSemaphore() +__attack_report_generating_lock = BoundedSemaphore() +__regular_report_generating_lock = BoundedSemaphore() def safe_generate_reports(): From d0fda6b9e5e4a3cc17fad6bf8eb5cbf31a47926f Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Thu, 15 Oct 2020 14:57:59 +0300 Subject: [PATCH 04/73] Fixed import styles in gevent modifications. --- monkey/monkey_island.py | 1 + monkey/monkey_island/cc/services/infection_lifecycle.py | 4 ++-- .../services/reporting/report_generation_synchronisation.py | 1 + 3 files changed, 4 insertions(+), 2 deletions(-) diff --git a/monkey/monkey_island.py b/monkey/monkey_island.py index 44b347e8c..cd452066c 100644 --- a/monkey/monkey_island.py +++ b/monkey/monkey_island.py @@ -1,4 +1,5 @@ from gevent import monkey as gevent_monkey + gevent_monkey.patch_all() from monkey_island.cc.main import main diff --git a/monkey/monkey_island/cc/services/infection_lifecycle.py b/monkey/monkey_island/cc/services/infection_lifecycle.py index 298db3e25..f29b9ba71 100644 --- a/monkey/monkey_island/cc/services/infection_lifecycle.py +++ b/monkey/monkey_island/cc/services/infection_lifecycle.py @@ -8,8 +8,8 @@ from monkey_island.cc.resources.test.utils.telem_store import TestTelemStore from monkey_island.cc.services.config import ConfigService from monkey_island.cc.services.node import NodeService from monkey_island.cc.services.reporting.report import ReportService -from monkey_island.cc.services.reporting.report_generation_synchronisation import safe_generate_reports, \ - is_report_being_generated +from monkey_island.cc.services.reporting.report_generation_synchronisation import ( + is_report_being_generated, safe_generate_reports) logger = logging.getLogger(__name__) diff --git a/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py b/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py index 944989b53..990df24e4 100644 --- a/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py +++ b/monkey/monkey_island/cc/services/reporting/report_generation_synchronisation.py @@ -1,4 +1,5 @@ import logging + from gevent.lock import BoundedSemaphore logger = logging.getLogger(__name__) From c6b7f4f0bebc67fc8452e7a44c0548242473a7b6 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Tue, 20 Oct 2020 10:12:10 +0300 Subject: [PATCH 05/73] Brought back and refactored run on AWS button. --- .../pages/RunMonkeyPage/AWSRunButton.js | 75 ++++++++++++ .../pages/RunMonkeyPage/AWSRunInstances.js | 108 ++++++++++++++++++ .../RunMonkeyPage}/AwsRunTable.js | 0 .../pages/RunMonkeyPage/RunOptions.js | 2 + .../monkey_island/cc/ui/src/styles/Main.scss | 1 + .../cc/ui/src/styles/components/Buttons.scss | 6 + 6 files changed, 192 insertions(+) create mode 100644 monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunButton.js create mode 100644 monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunInstances.js rename monkey/monkey_island/cc/ui/src/components/{run-monkey => pages/RunMonkeyPage}/AwsRunTable.js (100%) create mode 100644 monkey/monkey_island/cc/ui/src/styles/components/Buttons.scss diff --git a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunButton.js b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunButton.js new file mode 100644 index 000000000..f176ba0b5 --- /dev/null +++ b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunButton.js @@ -0,0 +1,75 @@ +import React, {useEffect, useState} from 'react'; +import AuthComponent from '../../AuthComponent'; +import '../../../styles/components/RunOnIslandButton.scss'; +import {faCloud} from '@fortawesome/free-solid-svg-icons'; +import AWSRunInstances from './AWSRunInstances'; +import NextSelectionButton from '../../ui-components/inline-selection/NextSelectionButton'; +import {Alert, Button} from 'react-bootstrap'; + + +function AWSRunButton(props) { + + const authComponent = new AuthComponent({}); + + const [isOnAWS, setIsOnAWS] = useState(false); + const [AWSInstances, setAWSInstances] = useState([]); + const [awsMachineCollectionError, setAwsMachineCollectionError] = useState(''); + + useEffect(() => { + checkIsOnAWS(); + }, []); + + function checkIsOnAWS() { + authComponent.authFetch('/api/remote-monkey?action=list_aws') + .then(res => res.json()) + .then(res => { + let isAws = res['is_aws']; + + if (isAws) { + // On AWS! + // Checks if there was an error while collecting the aws machines. + let isErrorWhileCollectingAwsMachines = (res['error'] != null); + if (isErrorWhileCollectingAwsMachines) { + // There was an error. Finish loading, and display error message. + setIsOnAWS(true); + setAwsMachineCollectionError(res['error']); + } else { + // No error! Finish loading and display machines for user + setIsOnAWS(true); + setAWSInstances(res['instances']); + } + } + }); + } + + function getAWSButton() { + return { + props.setComponent(AWSRunInstances, + {AWSInstances: AWSInstances, setComponent: props.setComponent}) + }}/> + } + + function getErrorDisplay() { + return ( + Detected ability to run on different AWS instances. + To enable this feature, follow the   + and refresh the page. Error received while trying to list AWS instances: {awsMachineCollectionError} + ); + } + + let displayed = ''; + if (awsMachineCollectionError !== '') { + displayed = getErrorDisplay(); + } else if (isOnAWS) { + displayed = getAWSButton(); + } + return displayed; +} + +export default AWSRunButton; diff --git a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunInstances.js b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunInstances.js new file mode 100644 index 000000000..4cc4f4e88 --- /dev/null +++ b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunInstances.js @@ -0,0 +1,108 @@ +import React, {useEffect, useState} from 'react'; +import {Button, Nav} from 'react-bootstrap'; + +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import {faSync} from '@fortawesome/free-solid-svg-icons/faSync'; +import '../../../styles/components/RunOnIslandButton.scss'; +import {faInfoCircle} from '@fortawesome/free-solid-svg-icons/faInfoCircle'; +import AwsRunTable from './AwsRunTable'; +import AuthComponent from '../../AuthComponent'; + + +function AWSRunInstances(props) { + + const authComponent = new AuthComponent({}); + + let awsTable = null + let [allIPs, setAllIPs] = useState([]); + let [selectedIp, setSelectedIp] = useState(null); + let [AWSClicked, setAWSClicked] = useState(false); + + useEffect(() => { + getIps(); + }, [allIPs]); + + function getIps() { + this.authFetch('/api') + .then(res => res.json()) + .then(res => { + setAllIPs(res['ip_addresses']); + setSelectedIp(res['ip_addresses'][0]); + }); + } + + function runOnAws() { + setAWSClicked(true); + let instances = awsTable.state.selection.map(x => instanceIdToInstance(x)); + + authComponent.authFetch('/api/remote-monkey', + { + method: 'POST', + headers: {'Content-Type': 'application/json'}, + body: JSON.stringify({type: 'aws', instances: instances, island_ip: selectedIp}) + }).then(res => res.json()) + .then(res => { + let result = res['result']; + + // update existing state, not run-over + let prevRes = awsTable.state.result; + for (let key in result) { + if (result.hasOwnProperty(key)) { + prevRes[key] = result[key]; + } + } + awsTable.setState({ + result: prevRes, + selection: [], + selectAll: false + }); + setAWSClicked(false); + }); + } + + function instanceIdToInstance(instance_id) { + let instance = props.AWSInstances.find( + function (inst) { + return inst['instance_id'] === instance_id; + }); + + return {'instance_id': instance_id, 'os': instance['os']} + } + + return ( +
+
+

+ + Not sure what this is? Not seeing your AWS EC2 instances? Read the documentation! +

+
+ { + allIPs.length > 1 ? + + :
+ } + (awsTable = r)} + /> +
+ +
+
+ ); +} + +export default AWSRunInstances; diff --git a/monkey/monkey_island/cc/ui/src/components/run-monkey/AwsRunTable.js b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AwsRunTable.js similarity index 100% rename from monkey/monkey_island/cc/ui/src/components/run-monkey/AwsRunTable.js rename to monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AwsRunTable.js diff --git a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOptions.js b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOptions.js index a9fe1f8cf..e7c14c217 100644 --- a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOptions.js +++ b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOptions.js @@ -7,6 +7,7 @@ import InlineSelection from '../../ui-components/inline-selection/InlineSelectio import {cloneDeep} from 'lodash'; import {faExpandArrowsAlt} from '@fortawesome/free-solid-svg-icons'; import RunOnIslandButton from './RunOnIslandButton'; +import AWSRunButton from './AWSRunButton'; function RunOptions(props) { @@ -61,6 +62,7 @@ function RunOptions(props) { setComponent(LocalManualRunOptions, {ips: ips, setComponent: setComponent}) }}/> + ); } diff --git a/monkey/monkey_island/cc/ui/src/styles/Main.scss b/monkey/monkey_island/cc/ui/src/styles/Main.scss index 616217e52..4e8419c82 100644 --- a/monkey/monkey_island/cc/ui/src/styles/Main.scss +++ b/monkey/monkey_island/cc/ui/src/styles/Main.scss @@ -17,6 +17,7 @@ @import 'components/inline-selection/BackButton'; @import 'components/inline-selection/CommandDisplay'; @import 'components/Icons'; +@import 'components/Buttons'; // Define custom elements after bootstrap import diff --git a/monkey/monkey_island/cc/ui/src/styles/components/Buttons.scss b/monkey/monkey_island/cc/ui/src/styles/components/Buttons.scss new file mode 100644 index 000000000..43bdc92fc --- /dev/null +++ b/monkey/monkey_island/cc/ui/src/styles/components/Buttons.scss @@ -0,0 +1,6 @@ +a.inline-link { + position: relative; + top: -1px; + margin: 0; + padding: 0; +} From d4002fd7b54080596ca0fce4495f2829bd731ecf Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Tue, 20 Oct 2020 12:04:57 +0300 Subject: [PATCH 06/73] Added loading component to indicate that more buttons are loading. --- .../src/components/pages/RunMonkeyPage/AWSRunButton.js | 7 ++++++- .../cc/ui/src/components/ui-components/LoadingIcon.js | 9 +++++++++ .../monkey_island/cc/ui/src/styles/components/Icons.scss | 7 +++++++ 3 files changed, 22 insertions(+), 1 deletion(-) create mode 100644 monkey/monkey_island/cc/ui/src/components/ui-components/LoadingIcon.js diff --git a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunButton.js b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunButton.js index f176ba0b5..42f16c614 100644 --- a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunButton.js +++ b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunButton.js @@ -5,6 +5,7 @@ import {faCloud} from '@fortawesome/free-solid-svg-icons'; import AWSRunInstances from './AWSRunInstances'; import NextSelectionButton from '../../ui-components/inline-selection/NextSelectionButton'; import {Alert, Button} from 'react-bootstrap'; +import LoadingIcon from '../../ui-components/LoadingIcon'; function AWSRunButton(props) { @@ -14,6 +15,7 @@ function AWSRunButton(props) { const [isOnAWS, setIsOnAWS] = useState(false); const [AWSInstances, setAWSInstances] = useState([]); const [awsMachineCollectionError, setAwsMachineCollectionError] = useState(''); + const [componentLoading, setComponentLoading] = useState(true); useEffect(() => { checkIsOnAWS(); @@ -24,7 +26,7 @@ function AWSRunButton(props) { .then(res => res.json()) .then(res => { let isAws = res['is_aws']; - + setComponentLoading(false); if (isAws) { // On AWS! // Checks if there was an error while collecting the aws machines. @@ -64,6 +66,9 @@ function AWSRunButton(props) { } let displayed = ''; + if (componentLoading) { + displayed = LoadingIcon(); + } if (awsMachineCollectionError !== '') { displayed = getErrorDisplay(); } else if (isOnAWS) { diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/LoadingIcon.js b/monkey/monkey_island/cc/ui/src/components/ui-components/LoadingIcon.js new file mode 100644 index 000000000..465ec7044 --- /dev/null +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/LoadingIcon.js @@ -0,0 +1,9 @@ +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import {faSync} from '@fortawesome/free-solid-svg-icons'; +import React from 'react'; + +function LoadingIcon() { + return +} + +export default LoadingIcon; diff --git a/monkey/monkey_island/cc/ui/src/styles/components/Icons.scss b/monkey/monkey_island/cc/ui/src/styles/components/Icons.scss index ed75d8a9d..7f8eadf05 100644 --- a/monkey/monkey_island/cc/ui/src/styles/components/Icons.scss +++ b/monkey/monkey_island/cc/ui/src/styles/components/Icons.scss @@ -1,3 +1,10 @@ +.loading-icon { + color: $monkey-yellow; + font-size: 20px; + margin-left: 50%; + margin-right: 50%; +} + .spinning-icon { animation: spin-animation 0.5s infinite; display: inline-block; From 67f5962977b44b0b2dda4e9a419d700a2a1a7aef Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Tue, 20 Oct 2020 12:10:40 +0300 Subject: [PATCH 07/73] Changed webpack server to serve on all interfaces. Makes remote development easier. --- monkey/monkey_island/cc/ui/webpack.config.js | 1 + 1 file changed, 1 insertion(+) diff --git a/monkey/monkey_island/cc/ui/webpack.config.js b/monkey/monkey_island/cc/ui/webpack.config.js index 08c2a77f3..975e914ce 100644 --- a/monkey/monkey_island/cc/ui/webpack.config.js +++ b/monkey/monkey_island/cc/ui/webpack.config.js @@ -71,6 +71,7 @@ module.exports = { publicPath: '/' }, devServer: { + host: '0.0.0.0', proxy: { '/api': { target: 'https://localhost:5000', From 5da412e40cee03b656e0e9bfd0b1311f263cea09 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Wed, 21 Oct 2020 12:13:34 +0300 Subject: [PATCH 08/73] Fixed eslint to allow backticks syntax. --- monkey/monkey_island/cc/ui/.eslintrc | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/monkey/monkey_island/cc/ui/.eslintrc b/monkey/monkey_island/cc/ui/.eslintrc index 2cd52bb98..afc7f2b7a 100644 --- a/monkey/monkey_island/cc/ui/.eslintrc +++ b/monkey/monkey_island/cc/ui/.eslintrc @@ -35,7 +35,8 @@ "comma-dangle": 1, "quotes": [ 1, - "single" + "single", + {"allowTemplateLiterals": true} ], "no-undef": 1, "global-strict": 0, From 46de8000c1acf9eec0bbd871c153cb67e6598975 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Wed, 21 Oct 2020 12:15:16 +0300 Subject: [PATCH 09/73] Fixed and moved AWS run components into a separate folder --- .../pages/RunMonkeyPage/AwsRunTable.js | 109 ---------------- .../RunOnAWS/AWSInstanceTable.js | 119 ++++++++++++++++++ .../{ => RunOnAWS}/AWSRunButton.js | 12 +- .../AWSRunOptions.js} | 43 ++++--- .../cc/ui/src/styles/pages/MonkeyRunPage.scss | 5 + 5 files changed, 156 insertions(+), 132 deletions(-) delete mode 100644 monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AwsRunTable.js create mode 100644 monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOnAWS/AWSInstanceTable.js rename monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/{ => RunOnAWS}/AWSRunButton.js (86%) rename monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/{AWSRunInstances.js => RunOnAWS/AWSRunOptions.js} (75%) diff --git a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AwsRunTable.js b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AwsRunTable.js deleted file mode 100644 index 8c7ccf490..000000000 --- a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AwsRunTable.js +++ /dev/null @@ -1,109 +0,0 @@ -import React from 'react'; -import ReactTable from 'react-table' -import checkboxHOC from 'react-table/lib/hoc/selectTable'; - -const CheckboxTable = checkboxHOC(ReactTable); - -const columns = [ - { - Header: 'Machines', - columns: [ - {Header: 'Machine', accessor: 'name'}, - {Header: 'Instance ID', accessor: 'instance_id'}, - {Header: 'IP Address', accessor: 'ip_address'}, - {Header: 'OS', accessor: 'os'} - ] - } -]; - -const pageSize = 10; - -class AwsRunTableComponent extends React.Component { - constructor(props) { - super(props); - this.state = { - selection: [], - selectAll: false, - result: {} - } - } - - toggleSelection = (key) => { - // start off with the existing state - let selection = [...this.state.selection]; - const keyIndex = selection.indexOf(key); - // check to see if the key exists - if (keyIndex >= 0) { - // it does exist so we will remove it using destructing - selection = [ - ...selection.slice(0, keyIndex), - ...selection.slice(keyIndex + 1) - ]; - } else { - // it does not exist so add it - selection.push(key); - } - // update the state - this.setState({selection}); - }; - - isSelected = key => { - return this.state.selection.includes(key); - }; - - toggleAll = () => { - const selectAll = !this.state.selectAll; - const selection = []; - if (selectAll) { - // we need to get at the internals of ReactTable - const wrappedInstance = this.checkboxTable.getWrappedInstance(); - // the 'sortedData' property contains the currently accessible records based on the filter and sort - const currentRecords = wrappedInstance.getResolvedState().sortedData; - // we just push all the IDs onto the selection array - currentRecords.forEach(item => { - selection.push(item._original.instance_id); - }); - } - this.setState({selectAll, selection}); - }; - - getTrProps = (_, r) => { - let color = 'inherit'; - if (r) { - let instId = r.original.instance_id; - if (this.isSelected(instId)) { - color = '#ffed9f'; - } else if (Object.prototype.hasOwnProperty.call(this.state.result, instId)) { - color = this.state.result[instId] ? '#00f01b' : '#f00000' - } - } - - return { - style: {backgroundColor: color} - }; - }; - - render() { - return ( -
- (this.checkboxTable = r)} - keyField="instance_id" - columns={columns} - data={this.props.data} - showPagination={true} - defaultPageSize={pageSize} - className="-highlight" - selectType="checkbox" - toggleSelection={this.toggleSelection} - isSelected={this.isSelected} - toggleAll={this.toggleAll} - selectAll={this.state.selectAll} - getTrProps={this.getTrProps} - /> -
- ); - } -} - -export default AwsRunTableComponent; diff --git a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOnAWS/AWSInstanceTable.js b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOnAWS/AWSInstanceTable.js new file mode 100644 index 000000000..cf792f7b8 --- /dev/null +++ b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOnAWS/AWSInstanceTable.js @@ -0,0 +1,119 @@ +import React, {useState} from 'react'; +import ReactTable from 'react-table' +import checkboxHOC from 'react-table/lib/hoc/selectTable'; +import PropTypes from 'prop-types'; + + +const CheckboxTable = checkboxHOC(ReactTable); + +const columns = [ + { + Header: 'Machines', + columns: [ + {Header: 'Machine', accessor: 'name'}, + {Header: 'Instance ID', accessor: 'instance_id'}, + {Header: 'IP Address', accessor: 'ip_address'}, + {Header: 'OS', accessor: 'os'} + ] + } +]; + +const pageSize = 10; + +function AWSInstanceTable(props) { + + const [allToggled, setAllToggled] = useState(false); + let checkboxTable = null; + + function toggleSelection(key) { + key = key.replace('select-', ''); + // start off with the existing state + let modifiedSelection = [...props.selection]; + const keyIndex = modifiedSelection.indexOf(key); + // check to see if the key exists + if (keyIndex >= 0) { + // it does exist so we will remove it using destructing + modifiedSelection = [ + ...modifiedSelection.slice(0, keyIndex), + ...modifiedSelection.slice(keyIndex + 1) + ]; + } else { + // it does not exist so add it + modifiedSelection.push(key); + } + // update the state + props.setSelection(modifiedSelection); + } + + function isSelected(key) { + return props.selection.includes(key); + } + + function toggleAll() { + const selectAll = !allToggled; + const selection = []; + if (selectAll) { + // we need to get at the internals of ReactTable + const wrappedInstance = checkboxTable.getWrappedInstance(); + // the 'sortedData' property contains the currently accessible records based on the filter and sort + const currentRecords = wrappedInstance.getResolvedState().sortedData; + // we just push all the IDs onto the selection array + currentRecords.forEach(item => { + selection.push(item._original.instance_id); + }); + } + setAllToggled(selectAll); + props.setSelection(selection); + } + + function getTrProps(_, r) { + let color = 'inherit'; + if (r) { + let instId = r.original.instance_id; + if (isSelected(instId)) { + color = '#ffed9f'; + } else if (Object.prototype.hasOwnProperty.call(props.results, instId)) { + color = props.results[instId] ? '#00f01b' : '#f00000' + } + } + + return { + style: {backgroundColor: color} + }; + } + + return ( +
+ (checkboxTable = r)} + keyField="instance_id" + columns={columns} + data={props.data} + showPagination={true} + defaultPageSize={pageSize} + className="-highlight" + selectType="checkbox" + toggleSelection={toggleSelection} + isSelected={isSelected} + toggleAll={toggleAll} + selectAll={allToggled} + getTrProps={getTrProps} + /> +
+ ); + +} + +AWSInstanceTable.propTypes = { + data: PropTypes.arrayOf(PropTypes.exact({ + instance_id: PropTypes.string, + name: PropTypes.string, + os: PropTypes.string, + ip_address: PropTypes.string + })), + results: PropTypes.arrayOf(PropTypes.string), + selection: PropTypes.arrayOf(PropTypes.string), + setSelection: PropTypes.func +} + +export default AWSInstanceTable; diff --git a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunButton.js b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOnAWS/AWSRunButton.js similarity index 86% rename from monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunButton.js rename to monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOnAWS/AWSRunButton.js index 42f16c614..3903d2a8e 100644 --- a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunButton.js +++ b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOnAWS/AWSRunButton.js @@ -1,11 +1,11 @@ import React, {useEffect, useState} from 'react'; -import AuthComponent from '../../AuthComponent'; -import '../../../styles/components/RunOnIslandButton.scss'; +import AuthComponent from '../../../AuthComponent'; +import '../../../../styles/components/RunOnIslandButton.scss'; import {faCloud} from '@fortawesome/free-solid-svg-icons'; -import AWSRunInstances from './AWSRunInstances'; -import NextSelectionButton from '../../ui-components/inline-selection/NextSelectionButton'; +import AWSRunOptions from './AWSRunOptions'; +import NextSelectionButton from '../../../ui-components/inline-selection/NextSelectionButton'; import {Alert, Button} from 'react-bootstrap'; -import LoadingIcon from '../../ui-components/LoadingIcon'; +import LoadingIcon from '../../../ui-components/LoadingIcon'; function AWSRunButton(props) { @@ -49,7 +49,7 @@ function AWSRunButton(props) { description={'Run on a chosen AWS instance in the cloud.'} icon={faCloud} onButtonClick={() => { - props.setComponent(AWSRunInstances, + props.setComponent(AWSRunOptions, {AWSInstances: AWSInstances, setComponent: props.setComponent}) }}/> } diff --git a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunInstances.js b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOnAWS/AWSRunOptions.js similarity index 75% rename from monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunInstances.js rename to monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOnAWS/AWSRunOptions.js index 4cc4f4e88..4c75e0ae3 100644 --- a/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/AWSRunInstances.js +++ b/monkey/monkey_island/cc/ui/src/components/pages/RunMonkeyPage/RunOnAWS/AWSRunOptions.js @@ -3,27 +3,36 @@ import {Button, Nav} from 'react-bootstrap'; import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; import {faSync} from '@fortawesome/free-solid-svg-icons/faSync'; -import '../../../styles/components/RunOnIslandButton.scss'; import {faInfoCircle} from '@fortawesome/free-solid-svg-icons/faInfoCircle'; -import AwsRunTable from './AwsRunTable'; -import AuthComponent from '../../AuthComponent'; +import AwsRunTable from './AWSInstanceTable'; +import AuthComponent from '../../../AuthComponent'; +import InlineSelection from '../../../ui-components/inline-selection/InlineSelection'; -function AWSRunInstances(props) { +const AWSRunOptions = (props) => { + return InlineSelection(getContents, { + ...props, + onBackButtonClick: () => {props.setComponent()} + }) +} + + +const getContents = (props) => { const authComponent = new AuthComponent({}); - let awsTable = null let [allIPs, setAllIPs] = useState([]); let [selectedIp, setSelectedIp] = useState(null); let [AWSClicked, setAWSClicked] = useState(false); + let [runResults, setRunResults] = useState([]); + let [selectedInstances, setSelectedInstances] = useState([]); useEffect(() => { getIps(); - }, [allIPs]); + }, []); function getIps() { - this.authFetch('/api') + authComponent.authFetch('/api') .then(res => res.json()) .then(res => { setAllIPs(res['ip_addresses']); @@ -33,7 +42,7 @@ function AWSRunInstances(props) { function runOnAws() { setAWSClicked(true); - let instances = awsTable.state.selection.map(x => instanceIdToInstance(x)); + let instances = selectedInstances.map(x => instanceIdToInstance(x)); authComponent.authFetch('/api/remote-monkey', { @@ -45,17 +54,14 @@ function AWSRunInstances(props) { let result = res['result']; // update existing state, not run-over - let prevRes = awsTable.state.result; + let prevRes = result; for (let key in result) { if (result.hasOwnProperty(key)) { prevRes[key] = result[key]; } } - awsTable.setState({ - result: prevRes, - selection: [], - selectAll: false - }); + setRunResults(prevRes); + setSelectedInstances([]); setAWSClicked(false); }); } @@ -89,10 +95,13 @@ function AWSRunInstances(props) { } (awsTable = r)} + results={runResults} + selection={selectedInstances} + setSelection={setSelectedInstances} /> -
+
From f371a33e5b9604ce9ee9503b02c7452d468814d1 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Wed, 21 Oct 2020 15:18:04 +0300 Subject: [PATCH 12/73] Doc update in accordance to UI changes for AWS run button (screenshots updated, descriptions updated) --- .../integrations/aws-run-on-ec2-machine.md | 11 +++++------ .../monkey-island-aws-screenshot-1.png | Bin 52324 -> 73549 bytes .../monkey-island-aws-screenshot-2.png | Bin 45357 -> 99758 bytes 3 files changed, 5 insertions(+), 6 deletions(-) diff --git a/docs/content/usage/integrations/aws-run-on-ec2-machine.md b/docs/content/usage/integrations/aws-run-on-ec2-machine.md index 0183dc241..e30a8b554 100644 --- a/docs/content/usage/integrations/aws-run-on-ec2-machine.md +++ b/docs/content/usage/integrations/aws-run-on-ec2-machine.md @@ -54,16 +54,15 @@ See [Amazon's documentation about working with SSM agents](https://docs.aws.amaz ### Running the monkey -When you run the monkey island on an AWS instance, the island detects it's running on AWS and present the following option in the _"Run Monkey"_ page, like so: +When you run the Monkey Island on an AWS instance, the island detects it's running on AWS and present the following option in the _"Run Monkey"_ page, like so: ![Running a Monkey on EC2 Instance](/images/usage/integrations/monkey-island-aws-screenshot-1.png "Running a Monkey on EC2 Instance") -And then you can choose one of the available instances as "patient zero" like so: +After you click on "AWS run" you can choose one of the available instances as "patient zero" like so: -1. Click on "Run on AWS" -2. Choose the relevant Network Interface -3. Select the machines you'd like to run the Monkey on -4. Click "Run on Selected Machines", and watch the monkey go! 🐒 +1. Choose the relevant Network Interface +2. Select the machines you'd like to run the Monkey on +3. Click "Run on Selected Machines", and watch the monkey go! 🐒 ![Running a Monkey on EC2 Instance](/images/usage/integrations/monkey-island-aws-screenshot-2.png "Running a Monkey on EC2 Instance") diff --git a/docs/static/images/usage/integrations/monkey-island-aws-screenshot-1.png b/docs/static/images/usage/integrations/monkey-island-aws-screenshot-1.png index 0b1af5fae5dd931dab9ad47d1224dcf3798e18b3..ba61e2b7c370e6360bdd9912cfdbda89072afaa7 100644 GIT binary patch literal 73549 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 X`$x3Q*~a;gX%g_=2X@s4d~@b^rQj$C literal 52324 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

@QnWt9@HIfW~{PV^0HBUJb$>zdT|4T4<5QS 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

a+!q-e^Z}&uV;r8 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 diff --git a/docs/static/images/usage/integrations/monkey-island-aws-screenshot-2.png b/docs/static/images/usage/integrations/monkey-island-aws-screenshot-2.png index f6442e82b5ba03194d15c0f6a479b7d8fa7a3c02..ad9f6ed813824d3347f5751156dad8832312eb31 100644 GIT binary patch literal 99758 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%0A7RpQ7_J0DKjqJoBE}vV2)SPteSts-beXfK$W|D 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

vEI}z_u|EPQq(3~3Qr5}b{IWs#48hKd0(B% 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 literal 45357 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 From 2e35b9ac4334038128b45e4642412863ccf0b1a7 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Thu, 5 Nov 2020 14:57:50 +0200 Subject: [PATCH 13/73] Initial implementation of validation script --- .travis.yml | 11 ++++------- ci_scripts/.gitignore | 2 ++ ci_scripts/README.md | 7 +++++++ ci_scripts/flake8_linter_check.cfg | 15 +++++++++++++++ ci_scripts/flake8_syntax_check.cfg | 9 +++++++++ ci_scripts/install_requirements.ps1 | 5 +++++ ci_scripts/isort.cfg | 5 +++++ ci_scripts/requirements.txt | 6 ++++++ ci_scripts/validate.ps1 | 20 ++++++++++++++++++++ 9 files changed, 73 insertions(+), 7 deletions(-) create mode 100644 ci_scripts/.gitignore create mode 100644 ci_scripts/README.md create mode 100644 ci_scripts/flake8_linter_check.cfg create mode 100644 ci_scripts/flake8_syntax_check.cfg create mode 100644 ci_scripts/install_requirements.ps1 create mode 100644 ci_scripts/isort.cfg create mode 100644 ci_scripts/requirements.txt create mode 100644 ci_scripts/validate.ps1 diff --git a/.travis.yml b/.travis.yml index 887b7cc67..35f6210cb 100644 --- a/.travis.yml +++ b/.travis.yml @@ -60,20 +60,17 @@ before_script: script: # Check Python code -## Check syntax errors and fail the build if any are found. -- flake8 . --count --select=E901,E999,F821,F822,F823 --show-source --statistics +- flake8 ./monkey --config ./ci_scripts/flake8_syntax_check.config ## Warn about linter issues. ### --exit-zero forces Flake8 to use the exit status code 0 even if there are errors, which means this will NOT fail the build. -### --count will print the total number of errors. -### --statistics Count the number of occurrences of each error/warning code and print a report. ### The output is redirected to a file. -- flake8 . --count --exit-zero --max-complexity=10 --max-line-length=127 --statistics > flake8_warnings.txt +- flake8 ./monkey --exit-zero --config ./ci_scripts/flake8_linter_check.config > ./ci_scripts/flake8_warnings.txt ## Display the linter issues -- cat flake8_warnings.txt +- cat ./ci_scripts/flake8_warnings.txt ## Make sure that we haven't increased the amount of warnings. - PYTHON_WARNINGS_AMOUNT_UPPER_LIMIT=80 -- if [ $(tail -n 1 flake8_warnings.txt) -gt $PYTHON_WARNINGS_AMOUNT_UPPER_LIMIT ]; then echo "Too many python linter warnings! Failing this build. Lower the amount of linter errors in this and try again. " && exit 1; fi +- if [ $(tail -n 1 ./ci_scripts/flake8_warnings.txt) -gt $PYTHON_WARNINGS_AMOUNT_UPPER_LIMIT ]; then echo "Too many python linter warnings! Failing this build. Lower the amount of linter errors in this and try again. " && exit 1; fi ## Check import order - python -m isort . -c -p common -p infection_monkey -p monkey_island diff --git a/ci_scripts/.gitignore b/ci_scripts/.gitignore new file mode 100644 index 000000000..67f93fcdc --- /dev/null +++ b/ci_scripts/.gitignore @@ -0,0 +1,2 @@ +./validation-env +./flake8_warnings.txt diff --git a/ci_scripts/README.md b/ci_scripts/README.md new file mode 100644 index 000000000..af555a7dd --- /dev/null +++ b/ci_scripts/README.md @@ -0,0 +1,7 @@ +# About + +Run this script to validate your code locally and auto fix/format the problems before pushing. + +# Usage + +run from `infection_monkey` directory: `powershell .\ci_scripts\validate.ps1` diff --git a/ci_scripts/flake8_linter_check.cfg b/ci_scripts/flake8_linter_check.cfg new file mode 100644 index 000000000..b8daeaf70 --- /dev/null +++ b/ci_scripts/flake8_linter_check.cfg @@ -0,0 +1,15 @@ +[flake8] +## Warn about linter issues. + +exclude = ../monkey/monkey_island/cc/ui, + ../monkey/common/cloud +show-source = True +max-complexity = 10 +max-line-length = 127 + +### --statistics Count the number of occurrences of each error/warning code and print a report. +statistics = True + +### --count will print the total number of errors. +count = True + diff --git a/ci_scripts/flake8_syntax_check.cfg b/ci_scripts/flake8_syntax_check.cfg new file mode 100644 index 000000000..7171e3db6 --- /dev/null +++ b/ci_scripts/flake8_syntax_check.cfg @@ -0,0 +1,9 @@ +[flake8] + +## Check syntax errors and fail the build if any are found. +exclude = ../monkey/monkey_island/cc/ui, + ../monkey/common/cloud +select = E901,E999,F821,F822,F823 +count = True +show-source = True +statistics = True diff --git a/ci_scripts/install_requirements.ps1 b/ci_scripts/install_requirements.ps1 new file mode 100644 index 000000000..de42d8599 --- /dev/null +++ b/ci_scripts/install_requirements.ps1 @@ -0,0 +1,5 @@ +python -m venv validation-env +.\validation-env\Scripts\activate.ps1 +python -m pip install -r .\requirements.txt +npm i -g eslint +deactivate diff --git a/ci_scripts/isort.cfg b/ci_scripts/isort.cfg new file mode 100644 index 000000000..f9a62b0ed --- /dev/null +++ b/ci_scripts/isort.cfg @@ -0,0 +1,5 @@ +[settings] +project=common,infection_monkey,monkey_island +skip=./monkey/common/cloud/scoutsuite,./monkey/monkey_island/cc/services/zero_trust/scoutsuite/data_parsing/rule_path_building/rule_path_creators_list.py,./monkey/monkey_island/cc/ui +line-length=120 +wrap-length=120 diff --git a/ci_scripts/requirements.txt b/ci_scripts/requirements.txt new file mode 100644 index 000000000..2b7db1909 --- /dev/null +++ b/ci_scripts/requirements.txt @@ -0,0 +1,6 @@ +flake8 +pytest +dlint +isort +coverage +black diff --git a/ci_scripts/validate.ps1 b/ci_scripts/validate.ps1 new file mode 100644 index 000000000..98a0ab4dd --- /dev/null +++ b/ci_scripts/validate.ps1 @@ -0,0 +1,20 @@ +.\ci_scripts\validation-env\Scripts\activate.ps1 +flake8 ./monkey --config ./ci_scripts/flake8_syntax_check.cfg +flake8 ./monkey --exit-zero --config ./ci_scripts/flake8_linter_check.cfg | Out-File -FilePath .\ci_scripts\flake8_warnings.txt +Get-Content -Path .\ci_scripts\flake8_warnings.txt +$PYTHON_WARNINGS_AMOUNT_UPPER_LIMIT = 80 +if ((Get-Item -Path .\ci_scripts\flake8_warnings.txt | Get-Content -Tail 1) -gt $PYTHON_WARNINGS_AMOUNT_UPPER_LIMIT){ + "Too many python linter warnings! Failing this build. Lower the amount of linter errors in this and try again. " + exit +} +python -m isort ./monkey -c --settings-file ./ci_scripts/isort.cfg +# python -m isort ./monkey --settings-file ./ci_scripts/isort.cfg +python monkey_island/cc/environment/set_server_config.py testing +python -m pytest +Push-Location -Path .\monkey_island\cc\ui +eslint ./src -c ./.eslintrc + +Pop-Location +Pop-Location +$null = $Host.UI.RawUI.ReadKey('NoEcho,IncludeKeyDown'); +deactivate From 636fb1be89a63f413fa58bcf5ba6e8c1e8323d72 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Fri, 6 Nov 2020 11:47:38 +0200 Subject: [PATCH 14/73] Added option to rollback the changes done in "set_server_config" --- .../cc/environment/set_server_config.py | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/monkey/monkey_island/cc/environment/set_server_config.py b/monkey/monkey_island/cc/environment/set_server_config.py index d31dd6916..8c5c12b63 100644 --- a/monkey/monkey_island/cc/environment/set_server_config.py +++ b/monkey/monkey_island/cc/environment/set_server_config.py @@ -3,6 +3,7 @@ import json import logging import sys from pathlib import Path +from shutil import move def add_monkey_dir_to_sys_path(): @@ -16,6 +17,7 @@ add_monkey_dir_to_sys_path() from monkey_island.cc.environment.environment_config import EnvironmentConfig # noqa: E402 isort:skip SERVER_CONFIG = "server_config" +BACKUP_CONFIG_FILENAME = "./server_config.backup" logger = logging.getLogger(__name__) logger.addHandler(logging.StreamHandler()) @@ -26,10 +28,19 @@ def main(): args = parse_args() file_path = EnvironmentConfig.get_config_file_path() + if args.server_config == "restore": + restore_previous_config(file_path) + quit() + # Read config with open(file_path) as config_file: config_data = json.load(config_file) + # Backup the config + with open(BACKUP_CONFIG_FILENAME, "w") as backup_file: + json.dump(config_data, backup_file, indent=4) + backup_file.write("\n") + # Edit the config config_data[SERVER_CONFIG] = args.server_config @@ -42,10 +53,14 @@ def main(): def parse_args(): parser = argparse.ArgumentParser() - parser.add_argument("server_config", choices=["standard", "testing", "password"]) + parser.add_argument("server_config", choices=["standard", "testing", "password", "restore"]) args = parser.parse_args() return args +def restore_previous_config(config_path): + move(BACKUP_CONFIG_FILENAME, config_path) + + if __name__ == '__main__': main() From 1f1682fad8be3934d2893c22a48ca74ed3af3918 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Fri, 6 Nov 2020 11:48:52 +0200 Subject: [PATCH 15/73] Exported multiple configurations of CI tools to separate configurations, improved script --- .travis.yml | 2 +- ci_scripts/README.md | 1 + ci_scripts/isort.cfg | 11 ++++++----- ci_scripts/validate.ps1 | 29 ++++++++++++++++++++++++----- monkey/pytest.ini | 2 +- 5 files changed, 33 insertions(+), 12 deletions(-) diff --git a/.travis.yml b/.travis.yml index 35f6210cb..3e4d3104a 100644 --- a/.travis.yml +++ b/.travis.yml @@ -73,7 +73,7 @@ script: - if [ $(tail -n 1 ./ci_scripts/flake8_warnings.txt) -gt $PYTHON_WARNINGS_AMOUNT_UPPER_LIMIT ]; then echo "Too many python linter warnings! Failing this build. Lower the amount of linter errors in this and try again. " && exit 1; fi ## Check import order -- python -m isort . -c -p common -p infection_monkey -p monkey_island +- python -m isort ./monkey --settings-file ./ci_scripts/isort.cfg ## Run unit tests - cd monkey # This is our source dir diff --git a/ci_scripts/README.md b/ci_scripts/README.md index af555a7dd..09330d298 100644 --- a/ci_scripts/README.md +++ b/ci_scripts/README.md @@ -4,4 +4,5 @@ Run this script to validate your code locally and auto fix/format the problems b # Usage +You've got to manually download swimm for swimm validation. run from `infection_monkey` directory: `powershell .\ci_scripts\validate.ps1` diff --git a/ci_scripts/isort.cfg b/ci_scripts/isort.cfg index f9a62b0ed..d8651febd 100644 --- a/ci_scripts/isort.cfg +++ b/ci_scripts/isort.cfg @@ -1,5 +1,6 @@ -[settings] -project=common,infection_monkey,monkey_island -skip=./monkey/common/cloud/scoutsuite,./monkey/monkey_island/cc/services/zero_trust/scoutsuite/data_parsing/rule_path_building/rule_path_creators_list.py,./monkey/monkey_island/cc/ui -line-length=120 -wrap-length=120 +[isort] + +# Possible options: https://pycqa.github.io/isort/docs/configuration/options/ + +known_first_party=common,infection_monkey,monkey_island +skip=monkey/common/cloud/scoutsuite,monkey/monkey_island/cc/services/zero_trust/scoutsuite/data_parsing/rule_path_building/rule_path_creators_list.py,monkey/monkey_island/cc/ui,monkey/common/cloud/scoutsuite diff --git a/ci_scripts/validate.ps1 b/ci_scripts/validate.ps1 index 98a0ab4dd..d85da6a2a 100644 --- a/ci_scripts/validate.ps1 +++ b/ci_scripts/validate.ps1 @@ -1,4 +1,7 @@ .\ci_scripts\validation-env\Scripts\activate.ps1 +$ErrorActionPreference = "Stop" +python -m pip install -r monkey/monkey_island/requirements.txt +python -m pip install -r monkey/infection_monkey/requirements.txt flake8 ./monkey --config ./ci_scripts/flake8_syntax_check.cfg flake8 ./monkey --exit-zero --config ./ci_scripts/flake8_linter_check.cfg | Out-File -FilePath .\ci_scripts\flake8_warnings.txt Get-Content -Path .\ci_scripts\flake8_warnings.txt @@ -8,13 +11,29 @@ if ((Get-Item -Path .\ci_scripts\flake8_warnings.txt | Get-Content -Tail 1) -gt exit } python -m isort ./monkey -c --settings-file ./ci_scripts/isort.cfg -# python -m isort ./monkey --settings-file ./ci_scripts/isort.cfg -python monkey_island/cc/environment/set_server_config.py testing +if (!$?) { + $confirmation = Read-Host "Isort found errors. Do you want to attmpt to fix them automatically? (y/n)" + if ($confirmation -eq 'y') { + python -m isort ./monkey --settings-file ./ci_scripts/isort.cfg + } +} +Push-Location -Path ./monkey +python ./monkey_island/cc/environment/set_server_config.py testing python -m pytest -Push-Location -Path .\monkey_island\cc\ui -eslint ./src -c ./.eslintrc +$lastCommandSucceeded = $? +python ./monkey_island/cc/environment/set_server_config.py restore +Pop-Location +if (!$lastCommandSucceeded) { + exit +} + +Push-Location -Path .\monkey\monkey_island\cc\ui +eslint ./src -c ./.eslintrc Pop-Location -Pop-Location + +swimm verify + +Write-Host "Script finished. Press any key to continue" $null = $Host.UI.RawUI.ReadKey('NoEcho,IncludeKeyDown'); deactivate diff --git a/monkey/pytest.ini b/monkey/pytest.ini index 3596bf5f6..9b1766fc2 100644 --- a/monkey/pytest.ini +++ b/monkey/pytest.ini @@ -3,5 +3,5 @@ log_cli = 1 log_cli_level = DEBUG log_cli_format = %(asctime)s [%(levelname)s] %(module)s.%(funcName)s.%(lineno)d: %(message)s log_cli_date_format=%H:%M:%S -addopts = -v --capture=sys +addopts = -v --capture=sys --ignore=common/cloud/scoutsuite norecursedirs = node_modules dist From 6401826ee362e7ddaf2535b51eb997e8d8d47332 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Fri, 6 Nov 2020 13:18:03 +0200 Subject: [PATCH 16/73] Fixed travis script bug, where flake8 didn't pick up its configuration file --- .travis.yml | 4 ++-- ...8_linter_check.cfg => flake8_linter_check.ini} | 0 ci_scripts/flake8_syntax_check.cfg | 9 --------- ci_scripts/flake8_syntax_check.ini | 15 +++++++++++++++ 4 files changed, 17 insertions(+), 11 deletions(-) rename ci_scripts/{flake8_linter_check.cfg => flake8_linter_check.ini} (100%) delete mode 100644 ci_scripts/flake8_syntax_check.cfg create mode 100644 ci_scripts/flake8_syntax_check.ini diff --git a/.travis.yml b/.travis.yml index 3e4d3104a..9906b2c34 100644 --- a/.travis.yml +++ b/.travis.yml @@ -60,12 +60,12 @@ before_script: script: # Check Python code -- flake8 ./monkey --config ./ci_scripts/flake8_syntax_check.config +- flake8 ./monkey --config=./ci_scripts/flake8_syntax_check.ini ## Warn about linter issues. ### --exit-zero forces Flake8 to use the exit status code 0 even if there are errors, which means this will NOT fail the build. ### The output is redirected to a file. -- flake8 ./monkey --exit-zero --config ./ci_scripts/flake8_linter_check.config > ./ci_scripts/flake8_warnings.txt +- flake8 ./monkey --exit-zero --config=./ci_scripts/flake8_linter_check.ini > ./ci_scripts/flake8_warnings.txt ## Display the linter issues - cat ./ci_scripts/flake8_warnings.txt ## Make sure that we haven't increased the amount of warnings. diff --git a/ci_scripts/flake8_linter_check.cfg b/ci_scripts/flake8_linter_check.ini similarity index 100% rename from ci_scripts/flake8_linter_check.cfg rename to ci_scripts/flake8_linter_check.ini diff --git a/ci_scripts/flake8_syntax_check.cfg b/ci_scripts/flake8_syntax_check.cfg deleted file mode 100644 index 7171e3db6..000000000 --- a/ci_scripts/flake8_syntax_check.cfg +++ /dev/null @@ -1,9 +0,0 @@ -[flake8] - -## Check syntax errors and fail the build if any are found. -exclude = ../monkey/monkey_island/cc/ui, - ../monkey/common/cloud -select = E901,E999,F821,F822,F823 -count = True -show-source = True -statistics = True diff --git a/ci_scripts/flake8_syntax_check.ini b/ci_scripts/flake8_syntax_check.ini new file mode 100644 index 000000000..969379326 --- /dev/null +++ b/ci_scripts/flake8_syntax_check.ini @@ -0,0 +1,15 @@ +[flake8] + +## Check syntax errors and fail the build if any are found. +exclude = + ../monkey/monkey_island/cc/ui, + ../monkey/common/cloud +select = + E901, + E999, + F821, + F822, + F823 +count = True +show-source = True +statistics = True From 424c666f659a8fcd193db57dc64802d56a12429d Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Tue, 24 Nov 2020 17:58:28 +0200 Subject: [PATCH 17/73] Fixed custom post breach action path bug. --- monkey/monkey_island/cc/resources/pba_file_download.py | 4 ++-- monkey/monkey_island/cc/services/post_breach_files.py | 3 ++- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/monkey/monkey_island/cc/resources/pba_file_download.py b/monkey/monkey_island/cc/resources/pba_file_download.py index ad0786f4f..5a616a0fc 100644 --- a/monkey/monkey_island/cc/resources/pba_file_download.py +++ b/monkey/monkey_island/cc/resources/pba_file_download.py @@ -1,7 +1,7 @@ import flask_restful from flask import send_from_directory -from monkey_island.cc.services.post_breach_files import UPLOADS_DIR +from monkey_island.cc.services.post_breach_files import UPLOADS_DIR_NAME __author__ = 'VakarisZ' @@ -13,4 +13,4 @@ class PBAFileDownload(flask_restful.Resource): # Used by monkey. can't secure. def get(self, path): - return send_from_directory(UPLOADS_DIR, path) + return send_from_directory(UPLOADS_DIR_NAME, path) diff --git a/monkey/monkey_island/cc/services/post_breach_files.py b/monkey/monkey_island/cc/services/post_breach_files.py index b198161ad..20064f4c4 100644 --- a/monkey/monkey_island/cc/services/post_breach_files.py +++ b/monkey/monkey_island/cc/services/post_breach_files.py @@ -11,7 +11,8 @@ logger = logging.getLogger(__name__) # Where to find file names in config PBA_WINDOWS_FILENAME_PATH = ['monkey', 'post_breach', 'PBA_windows_filename'] PBA_LINUX_FILENAME_PATH = ['monkey', 'post_breach', 'PBA_linux_filename'] -PBA_UPLOAD_PATH = ['monkey_island', 'cc', 'userUploads'] +UPLOADS_DIR_NAME = 'userUploads' +PBA_UPLOAD_PATH = ['monkey_island', 'cc', UPLOADS_DIR_NAME] UPLOADS_DIR = Path(*PBA_UPLOAD_PATH) From 70a899cc7dcf43989cbd745324a75ff473d0398e Mon Sep 17 00:00:00 2001 From: DeepSource Bot Date: Mon, 23 Nov 2020 07:35:14 +0000 Subject: [PATCH 18/73] Add .deepsource.toml --- docs/content/development/_index.md | 2 +- docs/content/usage/configuration/_index.md | 2 +- docs/content/usage/getting-started.md | 2 +- docs/content/usage/integrations/_index.md | 2 +- docs/content/usage/use-cases/_index.md | 2 +- docs/content/usage/use-cases/attack.md | 38 +++++++++++ .../usage/use-cases/credential-leak.md | 19 +++--- docs/content/usage/use-cases/ids-test.md | 55 --------------- .../content/usage/use-cases/network-breach.md | 12 +++- .../usage/use-cases/network-segmentation.md | 26 ++++---- docs/content/usage/use-cases/other.md | 63 ++++++++++++------ docs/content/usage/use-cases/zero-trust.md | 42 ++++++++++++ .../images/usage/scenarios/attack-matrix.png | Bin 0 -> 161825 bytes monkey/monkey_island/requirements.txt | 2 +- 14 files changed, 157 insertions(+), 110 deletions(-) create mode 100644 docs/content/usage/use-cases/attack.md delete mode 100644 docs/content/usage/use-cases/ids-test.md create mode 100644 docs/content/usage/use-cases/zero-trust.md create mode 100644 docs/static/images/usage/scenarios/attack-matrix.png diff --git a/docs/content/development/_index.md b/docs/content/development/_index.md index deab32e6c..f4b2acc85 100644 --- a/docs/content/development/_index.md +++ b/docs/content/development/_index.md @@ -15,7 +15,7 @@ Want to help secure networks? That's great! Here's a few short links to help you get started. -* [Getting up and running](../setup-development-environment) - To help you get a working development setup. +* [Getting up and running](./setup-development-environment) - To help you get a working development setup. * [Contributing guidelines](https://github.com/guardicore/monkey/blob/master/CONTRIBUTING.md) - Some guidelines to help you submit. ## What are we looking for? diff --git a/docs/content/usage/configuration/_index.md b/docs/content/usage/configuration/_index.md index f10d81ce1..0a3558805 100644 --- a/docs/content/usage/configuration/_index.md +++ b/docs/content/usage/configuration/_index.md @@ -17,4 +17,4 @@ This section of the documentation is incomplete and under active construction. See these documentation pages for information on each configuration value: -{{% children description=true %}} +{{% children description=true style="p"%}} diff --git a/docs/content/usage/getting-started.md b/docs/content/usage/getting-started.md index 63d2bbaec..958318552 100644 --- a/docs/content/usage/getting-started.md +++ b/docs/content/usage/getting-started.md @@ -15,7 +15,7 @@ After deploying the Monkey Island in your environment, navigate to `https:// " The Monkey likes working together. See these documentation pages for information on each integration the Monkey currently offers: -{{% children description=true %}} +{{% children description=true style="p"%}} diff --git a/docs/content/usage/use-cases/_index.md b/docs/content/usage/use-cases/_index.md index 389d5328a..836646100 100644 --- a/docs/content/usage/use-cases/_index.md +++ b/docs/content/usage/use-cases/_index.md @@ -18,4 +18,4 @@ No worries! The Monkey uses safe exploiters and does not cause any permanent sys ## Section contents -{{% children description=True %}} +{{% children description=True style="p"%}} diff --git a/docs/content/usage/use-cases/attack.md b/docs/content/usage/use-cases/attack.md new file mode 100644 index 000000000..ee2e002c7 --- /dev/null +++ b/docs/content/usage/use-cases/attack.md @@ -0,0 +1,38 @@ +--- +title: "MITRE ATT&CK assessment" +date: 2020-10-22T16:58:22+03:00 +draft: false +description: "Assess your network security detection and prevention capabilities." +weight: 2 +--- + +## Overview + +Infection Monkey can simulate various [ATT&CK](https://attack.mitre.org/matrices/enterprise/) techniques on the network. +Use it to assess your security solutions’ detection and prevention capabilities. Infection Monkey will help you find +which ATT&CK techniques go unnoticed and will provide recommendations about preventing them. + + +## Configuration + +- **ATT&CK matrix** You can use ATT&CK configuration section to select which techniques you want the Monkey to simulate. +Leave default settings for the full simulation. +- **Exploits -> Credentials** This configuration value will be used for brute-forcing. We use most popular passwords +and usernames, but feel free to adjust it according to the default passwords used in your network. Keep in mind that +long lists means longer scanning times. +- **Network -> Scope** Disable “Local network scan” and instead provide specific network ranges in +the “Scan target list”. + +![ATT&CK matrix](/images/usage/scenarios/attack-matrix.png "ATT&CK matrix") + +## Suggested run mode + +Run the Infection Monkey on as many machines in your environment as you can to get a better assessment. This can be easily +achieved by selecting the “Manual” run option and executing the command shown on different machines in your environment +manually or with your deployment tool. + +## Assessing results + +The **ATT&CK Report** shows the status of ATT&CK techniques simulations. Click on any technique to see more details +about it and potential mitigations. Keep in mind that each technique display contains a question mark symbol that +will take you to the official documentation of ATT&CK technique, where you can learn more about it. diff --git a/docs/content/usage/use-cases/credential-leak.md b/docs/content/usage/use-cases/credential-leak.md index 498e1ff54..923335e34 100644 --- a/docs/content/usage/use-cases/credential-leak.md +++ b/docs/content/usage/use-cases/credential-leak.md @@ -1,9 +1,9 @@ --- -title: "Credential Leak" +title: "Credentials Leak" date: 2020-08-12T13:04:25+03:00 draft: false -description: "Assess the impact of successful phishing attack, insider threat, or other form of credentials leak." -weight: 4 +description: "Assess the impact of a successful phishing attack, insider threat, or other form of credentials leak." +weight: 5 --- ## Overview @@ -16,8 +16,6 @@ where these credentials can be reused. ## Configuration -#### Important configuration values: - - **Exploits -> Credentials** After setting up the Island add the users’ **real** credentials (usernames and passwords) to the Monkey’s configuration (Don’t worry, this sensitive data is not accessible and is not distributed or used in any way other than being sent to the monkeys, and can be easily eliminated by resetting the Monkey Island’s configuration). @@ -26,15 +24,14 @@ For this to work, Monkey Island or initial Monkey needs to have access to SSH ke To make sure SSH keys were gathered successfully, refresh the page and check this configuration value after you run the Monkey (content of keys will not be displayed, it will appear as ``). -To simulate the damage from a successful phishing attack using the Infection Monkey, choose machines in your network -from potentially problematic group of machines, such as the laptop of one of your heavy email users or -one of your strong IT users (think of people who are more likely to correspond with people outside of -your organization). Execute the Monkey on chosen machines by clicking on “**1. Run Monkey**” from the left sidebar menu - and choosing “**Run on machine of your choice**”. +## Suggested run mode + +Execute the Monkey on a chosen machine in your network using the “Manual” run option. +Run the Monkey as a privileged user to make sure it gathers as many credentials from the system as possible. ![Exploit password and user lists](/images/usage/scenarios/user-password-lists.png "Exploit password and user lists") ## Assessing results -To assess the impact of leaked credentials see Security report. It's possible, that credential leak resulted in even +To assess the impact of leaked credentials see Security report. It's possible that credential leak resulted in even more leaked credentials, for that look into **Security report -> Stolen credentials**. diff --git a/docs/content/usage/use-cases/ids-test.md b/docs/content/usage/use-cases/ids-test.md deleted file mode 100644 index 89b1bbfb3..000000000 --- a/docs/content/usage/use-cases/ids-test.md +++ /dev/null @@ -1,55 +0,0 @@ ---- -title: "IDS/IPS Test" -date: 2020-08-12T13:07:47+03:00 -draft: false -description: "Test your network defence solutions." -weight: 5 ---- - -## Overview - -The Infection Monkey can help you verify that your security solutions are working the way you expected them to. - These may include your IR and SOC teams, your SIEM, your firewall, your endpoint security solution, and more. - -## Configuration - -#### Important configuration values: - -- **Monkey -> Post breach** Post breach actions simulate the actions an attacker would make on infected system. - To test something not present on the tool, you can provide your own file or command to be ran. - -The default configuration is good enough for many cases, but configuring testing scope and adding brute-force - credentials is a good bet in any scenario. - -Running the Monkey on both the Island and on a few other machines in the network manually is also recommended, - as it increases coverage and propagation rates. - - -![Post breach configuration](/images/usage/use-cases/ids-test.PNG "Post breach configuration") - -## Assessing results - -After running the Monkey, follow the Monkeys’ actions on the Monkey Island’s infection map. - -Now you can match this activity from the Monkey timeline display to your internal SIEM and make sure your security - solutions are identifying and correctly alerting on different attacks. - -- The red arrows indicate successful exploitations. If you see red arrows, those incidents ought to be reported as - exploitation attempts, so check whether you are receiving alerts from your security systems as expected. -- The orange arrows indicate scanning activity, usually used by attackers to locate potential vulnerabilities. - If you see orange arrows, those incidents ought to be reported as scanning attempts (and possibly as segmentation violations). -- The blue arrows indicate tunneling activity, usually used by attackers to infiltrate “protected” networks from - the Internet. Perhaps someone is trying to bypass your firewall to gain access to a protected service in your network? - Check if your micro-segmentation / firewall solution identify or report anything. - -While running this scenario, be on the lookout for the action that should arise: - Did you get a phone call telling you about suspicious activity inside your network? Are events flowing - into your security events aggregators? Are you getting emails from your IR teams? - Is the endpoint protection software you installed on machines in the network reporting on anything? Are your - compliance scanners detecting anything wrong? - -Lastly, check Zero Trust and Mitre ATT&CK reports, to see which attacks can be executed on the network and how to - fix it. - - ![Map](/images/usage/use-cases/map-full-cropped.png "Map") - diff --git a/docs/content/usage/use-cases/network-breach.md b/docs/content/usage/use-cases/network-breach.md index 46aee7228..962878ea6 100644 --- a/docs/content/usage/use-cases/network-breach.md +++ b/docs/content/usage/use-cases/network-breach.md @@ -3,7 +3,7 @@ title: "Network Breach" date: 2020-08-12T13:04:55+03:00 draft: false description: "Simulate an internal network breach and assess the potential impact." -weight: 1 +weight: 3 --- ## Overview @@ -17,7 +17,6 @@ Infection Monkey will help you assess the impact of internal network breach, by ## Configuration -#### Important configuration values: - **Exploits -> Exploits** You can review the exploits Infection Monkey will be using. By default all safe exploiters are selected. - **Exploits -> Credentials** This configuration value will be used for brute-forcing. We use most popular passwords @@ -34,6 +33,15 @@ all post breach actions. These actions simulate attacker's behaviour after getti ![Exploiter selector](/images/usage/use-cases/network-breach.PNG "Exploiter selector") +## Suggested run mode + +Decide which machines you want to simulate a breach on and use the “Manual” run option to start Monkeys there. +Use high privileges to run the Monkey to simulate an attacker that was able to elevate its privileges. +You could also simulate an attack initiated from an unidentified machine connected to the network (a technician +laptop, 3rd party vendor machine, etc) by running the Monkey on a dedicated machine with an IP in the network you +wish to test. + + ## Assessing results Check infection map and security report to see how far monkey managed to propagate in the network and which diff --git a/docs/content/usage/use-cases/network-segmentation.md b/docs/content/usage/use-cases/network-segmentation.md index 8b418c1b6..543b6e645 100644 --- a/docs/content/usage/use-cases/network-segmentation.md +++ b/docs/content/usage/use-cases/network-segmentation.md @@ -2,18 +2,18 @@ title: "Network Segmentation" date: 2020-08-12T13:05:05+03:00 draft: false -description: "Test network segmentation policies for apps that need ringfencing or tiers that require microsegmentation." -weight: 3 +description: "Verify your network is properly segmented." +weight: 4 --- ## Overview -Segmentation is a method of creating secure zones in data centers and cloud deployments that allows companies to - isolate workloads from one another and secure them individually, typically using policies. - A useful way to test the effectiveness of your segmentation is to ensure that your network segments are - properly separated, e,g, your Development is separated from your Production, your applications are separated from one - another etc. To security test is to verify that your network segmentation is configured properly. This way you make - sure that even if a certain attacker has breached your defenses, it can’t move laterally from point A to point B. +Segmentation is a method of creating secure zones in data centers and cloud deployments that allows companies to +isolate workloads from one another and secure them individually, typically using policies. A useful way to test +the effectiveness of your segmentation is to ensure that your network segments are properly separated, e,g, your +Development is separated from your Production, your applications are separated from one another etc. Use the +Infection Monkey to verify that your network segmentation is configured properly. This way you make sure that +even if a certain attacker has breached your defenses, it can’t move laterally between segments. [Segmentation is key](https://www.guardicore.com/use-cases/micro-segmentation/) to protecting your network, reducing the attack surface and minimizing the damage of a breach. The Monkey can help you test your segmentation settings with @@ -21,8 +21,6 @@ its cross-segment traffic testing feature. ## Configuration -#### Important configuration values: - - **Network -> Network analysis -> Network segmentation testing** This configuration setting allows you to define subnets that should be segregated from each other. If any of provided networks can reach each other, you'll see it in security report. @@ -32,12 +30,12 @@ its cross-segment traffic testing feature. all post breach actions. These actions simulate attacker's behaviour after getting access to a new system, so they might trigger your defence solutions which will interrupt segmentation test. -Execute Monkeys on machines in different subnetworks manually, by choosing “**1. Run Monkey**” from the left sidebar menu - and clicking on “**Run on machine of your choice**”. - Alternatively, you could provide valid credentials and allow Monkey to propagate to relevant subnetworks by itself. +## Suggested run mode + +Execute Monkeys on machines in different subnetworks using the “Manual” run option. Note that if Monkey can't communicate to the Island, it will - not be able to send scan results, so make sure all machines can reach the island. + not be able to send scan results, so make sure all machines can reach the island. ![How to configure network segmentation testing](/images/usage/scenarios/segmentation-config.png "How to configure network segmentation testing") diff --git a/docs/content/usage/use-cases/other.md b/docs/content/usage/use-cases/other.md index b709d8ba3..90c44a943 100644 --- a/docs/content/usage/use-cases/other.md +++ b/docs/content/usage/use-cases/other.md @@ -2,7 +2,7 @@ title: "Other" date: 2020-08-12T13:07:55+03:00 draft: false -description: "Tips and tricks about configuring monkey for your needs." +description: "Tips and tricks about configuring Monkeys for your needs." weight: 100 --- @@ -10,33 +10,52 @@ weight: 100 This page provides additional information about configuring monkeys, tips and tricks and creative usage scenarios. -## ATT&CK & Zero Trust scanning +## Custom behaviour -You can use **ATT&CK** configuration section to select which techniques you want to scan. Keep in mind that ATT&CK - matrix configuration just changes the overall configuration by modifying related fields, thus you should start by - modifying and saving the matrix. After that you can change credentials and scope of the scan, but exploiters, - post breach actions and other configuration values will be already chosen based on ATT&CK matrix and shouldn't be - modified. - -There's currently no way to configure monkey using Zero Trust framework, but regardless of configuration options, - you'll always be able to see ATT&CK and Zero Trust reports. +If you want Monkey to run some kind of script or a tool after it breaches a machine, you can configure it in +**Configuration -> Monkey -> Post breach**. Just input commands you want executed in the corresponding fields. +You can also upload files and call them through commands you entered in command fields. -## Tips and tricks +## Accelerate the test -- Use **Monkey -> Persistent scanning** configuration section to either have periodic scans or to increase - reliability of exploitations. - -- To increase propagation run monkey as root/administrator. This will ensure that monkey will gather credentials - on current system and use them to move laterally. +To improve scanning speed you could **specify a subnet instead of scanning all of the local network**. -- Every network has its old “skeleton keys” that should have long been discarded. Configure the Monkey with old and stale passwords, but make sure that they were really discarded using the Monkey. To add the old passwords, in the island’s configuration, go to the “Exploit password list” under “Basic - Credentials” and use the “+” button to add the old passwords to the configuration. For example, here we added a few extra passwords (and a username as well) to the configuration: +The following configuration values also have an impact on scanning speed: +- **Credentials** - the more usernames and passwords you input, the longer it will take the Monkey to scan machines having +remote access services. Monkeys try to stay elusive and leave a low impact, thus brute forcing takes longer than with +loud conventional tools. +- **Network scope** - scanning large networks with a lot of propagations can become unwieldy. Instead, try to scan your +networks bit by bit with multiple runs. +- **Post breach actions** - you can disable most of these if you only care about propagation. +- **Internal -> TCP scanner** - you can trim the list of ports monkey tries to scan increasing performance even further. + +## Combining different scenarios + +Infection Monkey is not limited to the scenarios mentioned in this section, once you get the hang of configuring it, +you might come up with your own use case or test all of suggested scenarios at the same time! Whatever you do, +Security, ATT&CK and Zero Trust reports will be waiting for you! + +## Persistent scanning + +Use **Monkey -> Persistent** scanning configuration section to either have periodic scans or to increase reliability of +exploitations by running consecutive Infection Monkey scans. + +## Credentials + +Every network has its old “skeleton keys” that should have long been discarded. Configure the Monkey with old and stale +passwords, but make sure that they were really discarded using the Monkey. To add the old passwords, in the island’s +configuration, go to the “Exploit password list” under “Basic - Credentials” and use the “+” button to add the old +passwords to the configuration. For example, here we added a few extra passwords (and a username as well) to the +configuration: ![Exploit password and user lists](/images/usage/scenarios/user-password-lists.png "Exploit password and user lists") -- To see the Monkey executing in real-time on your servers, add the **post-breach action** command: `wall “Infection Monkey was here”`. This post breach command will broadcast a message across all open terminals on the servers the Monkey breached, to achieve the following: Let you know the Monkey ran successfully on the server. let you follow the breach “live” alongside the infection map, and check which terminals are logged and monitored inside your network. See below: +## Check logged and monitored terminals + +To see the Monkey executing in real-time on your servers, add the **post-breach action** command: +`wall “Infection Monkey was here”`. This post breach command will broadcast a message across all open terminals on +the servers the Monkey breached, to achieve the following: Let you know the Monkey ran successfully on the server. +Let you follow the breach “live” alongside the infection map, and check which terminals are logged and monitored +inside your network. See below: ![How to configure post breach commands](/images/usage/scenarios/pba-example.png "How to configure post breach commands.") - -- If you're scanning a large network, consider narrowing the scope and scanning it bit by bit if scan times become too - long. Lowering the amount of credentials, exploiters or post breach actions can also help to lower scanning times. - diff --git a/docs/content/usage/use-cases/zero-trust.md b/docs/content/usage/use-cases/zero-trust.md new file mode 100644 index 000000000..de3e37d39 --- /dev/null +++ b/docs/content/usage/use-cases/zero-trust.md @@ -0,0 +1,42 @@ +--- +title: "Zero Trust assessment" +date: 2020-10-22T16:58:09+03:00 +draft: false +description: "See where you stand in your Zero Trust journey." +weight: 1 +--- + +## Overview + +Infection Monkey will help you assess your progress on your journey to achieve Zero Trust network. +The Infection Monkey will automatically assess your readiness across the different +[Zero Trust Extended Framework](https://www.forrester.com/report/The+Zero+Trust+eXtended+ZTX+Ecosystem/-/E-RES137210) principles. + +## Configuration + +- **Exploits -> Credentials** This configuration value will be used for brute-forcing. We use most popular passwords +and usernames, but feel free to adjust it according to the default passwords used in your network. +Keep in mind that long lists means longer scanning times. +- **Network -> Scope** Disable “Local network scan” and instead provide specific network ranges in the “Scan target list”. +- **Network -> Network analysis -> Network segmentation testing** This configuration setting allows you to define +subnets that should be segregated from each other. + +In general, other configuration value defaults should be good enough, but feel free to see the “Other” section +for tips and tricks about other features and in-depth configuration parameters you can use. + +![Exploit password and user lists](/images/usage/scenarios/user-password-lists.png "Exploit password and user lists") + +## Suggested run mode + +Run the Monkey on as many machines as you can. This can be easily achieved by selecting the “Manual” run option and +executing the command shown on different machines in your environment manually or with your deployment tool. +In addition, you can use any other run options you see fit. + +## Assessing results + +See the results in the Zero Trust report section. “The Summary” section will give you an idea about which Zero Trust +pillars were tested, how many tests were done and test statuses. Specific tests are described in the “Test Results” +section. The “Findings” section shows details about the Monkey actions. Click on “Events” of different findings to +observe what exactly Infection Monkey did and when it was done. This should make it easy to cross reference events +with your security solutions and alerts/logs. + diff --git a/docs/static/images/usage/scenarios/attack-matrix.png b/docs/static/images/usage/scenarios/attack-matrix.png new file mode 100644 index 0000000000000000000000000000000000000000..f6a040c1bd0f3a67392289c26b0f2622b1462d25 GIT binary patch literal 161825 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ʐ#qeprPxiRuWIzp|Ck?lAbuWp|XNR~k{r6hIa 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 TbPr{3{xtj3F1F}Xff@e=2Sl9J literal 0 HcmV?d00001 diff --git a/monkey/monkey_island/requirements.txt b/monkey/monkey_island/requirements.txt index 7e7272a87..cef10fcb7 100644 --- a/monkey/monkey_island/requirements.txt +++ b/monkey/monkey_island/requirements.txt @@ -10,7 +10,7 @@ dpath>=2.0 flask>=1.1 ipaddress>=1.0.23 jsonschema==3.2.0 -mongoengine>=0.20 +mongoengine==0.20 mongomock==3.19.0 netifaces>=0.10.9 pycryptodome==3.9.8 From 04e89411fbb80a8283c4ea0c4f0c4f4651a384ad Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Fri, 4 Dec 2020 15:44:40 +0200 Subject: [PATCH 19/73] SMB bugfixed to be able to exploit machine with smb v3, by not specifying preferred dialect for rpctransport --- monkey/infection_monkey/exploit/smbexec.py | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/monkey/infection_monkey/exploit/smbexec.py b/monkey/infection_monkey/exploit/smbexec.py index 153f64ac7..f3a7977a6 100644 --- a/monkey/infection_monkey/exploit/smbexec.py +++ b/monkey/infection_monkey/exploit/smbexec.py @@ -1,7 +1,6 @@ from logging import getLogger from impacket.dcerpc.v5 import scmr, transport -from impacket.smbconnection import SMB_DIALECT from common.utils.attack_utils import ScanStatus, UsageEnum from common.utils.exploit_enum import ExploitType @@ -121,8 +120,7 @@ class SmbExploiter(HostExploiter): for str_bind_format, port in SmbExploiter.KNOWN_PROTOCOLS.values(): rpctransport = transport.DCERPCTransportFactory(str_bind_format % (self.host.ip_addr,)) rpctransport.set_dport(port) - if hasattr(rpctransport, 'preferred_dialect'): - rpctransport.preferred_dialect(SMB_DIALECT) + rpctransport.setRemoteHost(self.host.ip_addr) if hasattr(rpctransport, 'set_credentials'): # This method exists only for selected protocol sequences. rpctransport.set_credentials(user, password, '', lm_hash, ntlm_hash, None) @@ -168,7 +166,7 @@ class SmbExploiter(HostExploiter): SmbExploiter.KNOWN_PROTOCOLS['445/SMB'][1])) return True - def set_vulnerable_port(self, host: VictimHost): + def set_vulnerable_port(self): if 'tcp-445' in self.host.services: self.vulnerable_port = "445" elif 'tcp-139' in self.host.services: From 55f4684e1e9f4375daa50ab19af4cbf644d35e24 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Fri, 4 Dec 2020 16:43:53 +0200 Subject: [PATCH 20/73] Fixed function call that had too many arguments in smbexec.py --- monkey/infection_monkey/exploit/smbexec.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/monkey/infection_monkey/exploit/smbexec.py b/monkey/infection_monkey/exploit/smbexec.py index f3a7977a6..c28887820 100644 --- a/monkey/infection_monkey/exploit/smbexec.py +++ b/monkey/infection_monkey/exploit/smbexec.py @@ -103,7 +103,7 @@ class SmbExploiter(HostExploiter): LOG.debug("Exploiter SmbExec is giving up...") return False - self.set_vulnerable_port(self.host) + self.set_vulnerable_port() # execute the remote dropper in case the path isn't final if remote_full_path.lower() != self._config.dropper_target_path_win_32.lower(): cmdline = DROPPER_CMDLINE_DETACHED_WINDOWS % {'dropper_path': remote_full_path} + \ From 5008b4eff061f9f7b6a461ced79e62af749a7d5e Mon Sep 17 00:00:00 2001 From: Shubhendra Singh Chauhan Date: Fri, 4 Dec 2020 23:06:56 +0530 Subject: [PATCH 22/73] Create .deepsource.toml --- .deepsource.toml | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 .deepsource.toml diff --git a/.deepsource.toml b/.deepsource.toml new file mode 100644 index 000000000..2461cfb80 --- /dev/null +++ b/.deepsource.toml @@ -0,0 +1,14 @@ +version = 1 + +test_patterns = ["**/**_test.py"] + +[[analyzers]] +name = "python" +enabled = true +dependency_file_paths = [ + "monkey/monkey_island/requirements.txt", + "monkey/infection_monkey/requirements.txt" + ] + + [analyzers.meta] + runtime_version = "3.x.x" From 96d28b40afbb0b148b6af8e600e6c7d6e1bf0ac3 Mon Sep 17 00:00:00 2001 From: "deepsource-autofix[bot]" <62050782+deepsource-autofix[bot]@users.noreply.github.com> Date: Fri, 4 Dec 2020 17:47:53 +0000 Subject: [PATCH 23/73] autofixe made using DeepSource --- monkey/infection_monkey/exploit/shellshock.py | 1 - monkey/infection_monkey/exploit/web_rce.py | 2 +- monkey/infection_monkey/network/network_scanner.py | 2 +- monkey/infection_monkey/network/tools.py | 2 +- .../windows_cred_collector/pypykatz_handler.py | 4 ++-- .../utils/plugins/pluginTests/BadImport.py | 2 -- monkey/monkey_island/cc/resources/monkey.py | 10 ++++------ .../monkey_island/cc/services/edge/displayed_edge.py | 2 +- .../cc/services/telemetry/processing/scan.py | 1 - 9 files changed, 10 insertions(+), 16 deletions(-) diff --git a/monkey/infection_monkey/exploit/shellshock.py b/monkey/infection_monkey/exploit/shellshock.py index f9548b6bf..edec8018e 100644 --- a/monkey/infection_monkey/exploit/shellshock.py +++ b/monkey/infection_monkey/exploit/shellshock.py @@ -228,7 +228,6 @@ class ShellShockExploiter(HostExploiter): Checks if which urls exist :return: Sequence of URLs to try and attack """ - import requests attack_path = 'http://' if is_https: attack_path = 'https://' diff --git a/monkey/infection_monkey/exploit/web_rce.py b/monkey/infection_monkey/exploit/web_rce.py index 0f489d0a6..f5db3e92f 100644 --- a/monkey/infection_monkey/exploit/web_rce.py +++ b/monkey/infection_monkey/exploit/web_rce.py @@ -56,7 +56,7 @@ class WebRCE(HostExploiter): Method that creates a dictionary of configuration values for exploit :return: configuration dict """ - exploit_config = dict() + exploit_config = {} # dropper: If true monkey will use dropper parameter that will detach monkey's process and try to copy # it's file to the default destination path. diff --git a/monkey/infection_monkey/network/network_scanner.py b/monkey/infection_monkey/network/network_scanner.py index 6abf409ad..95277b4b9 100644 --- a/monkey/infection_monkey/network/network_scanner.py +++ b/monkey/infection_monkey/network/network_scanner.py @@ -113,7 +113,7 @@ class NetworkScanner(object): :return: Victim or None if victim isn't alive """ LOG.debug("Scanning target address: %r", victim) - if any([scanner.is_host_alive(victim) for scanner in self.scanners]): + if any(scanner.is_host_alive(victim) for scanner in self.scanners): LOG.debug("Found potential target_ip: %r", victim) return victim else: diff --git a/monkey/infection_monkey/network/tools.py b/monkey/infection_monkey/network/tools.py index 049b30838..99b21d81c 100644 --- a/monkey/infection_monkey/network/tools.py +++ b/monkey/infection_monkey/network/tools.py @@ -139,7 +139,7 @@ def check_tcp_ports(ip, ports, timeout=DEFAULT_TIMEOUT, get_banner=False): timeout = int(round(timeout)) # clamp to integer, to avoid checking input sockets_to_try = possible_ports[:] connected_ports_sockets = [] - while (timeout >= 0) and len(sockets_to_try): + while (timeout >= 0) and sockets_to_try: sock_objects = [s[1] for s in sockets_to_try] _, writeable_sockets, _ = select.select(sock_objects, sock_objects, sock_objects, 0) diff --git a/monkey/infection_monkey/system_info/windows_cred_collector/pypykatz_handler.py b/monkey/infection_monkey/system_info/windows_cred_collector/pypykatz_handler.py index cba4c330a..35ff67678 100644 --- a/monkey/infection_monkey/system_info/windows_cred_collector/pypykatz_handler.py +++ b/monkey/infection_monkey/system_info/windows_cred_collector/pypykatz_handler.py @@ -67,8 +67,8 @@ def _get_windows_cred(pypykatz_cred: PypykatzCredential): def _hash_to_string(hash_: Any): - if type(hash_) == str: + if type(hash_) is str: return hash_ - if type(hash_) == bytes: + if type(hash_) is bytes: return binascii.hexlify(bytearray(hash_)).decode() raise Exception(f"Can't convert hash_ to string, unsupported hash_ type {type(hash_)}") diff --git a/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py b/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py index d28a91a89..1377d75be 100644 --- a/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py +++ b/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py @@ -1,5 +1,3 @@ -from infection_monkey.utils.plugins.pluginTests.PluginTestClass import \ - TestPlugin # noqa: F401 class SomeDummyPlugin: diff --git a/monkey/monkey_island/cc/resources/monkey.py b/monkey/monkey_island/cc/resources/monkey.py index 0962e6dd5..cd570903d 100644 --- a/monkey/monkey_island/cc/resources/monkey.py +++ b/monkey/monkey_island/cc/resources/monkey.py @@ -87,20 +87,18 @@ class Monkey(flask_restful.Resource): parent = monkey_json.get('parent') parent_to_add = (monkey_json.get('guid'), None) # default values in case of manual run if parent and parent != monkey_json.get('guid'): # current parent is known - exploit_telem = [x for x in - mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, + exploit_telem = list(mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, 'data.result': {'$eq': True}, 'data.machine.ip_addr': {'$in': monkey_json['ip_addresses']}, - 'monkey_guid': {'$eq': parent}})] + 'monkey_guid': {'$eq': parent}})) if 1 == len(exploit_telem): parent_to_add = (exploit_telem[0].get('monkey_guid'), exploit_telem[0].get('data').get('exploiter')) else: parent_to_add = (parent, None) elif (not parent or parent == monkey_json.get('guid')) and 'ip_addresses' in monkey_json: - exploit_telem = [x for x in - mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, + exploit_telem = list(mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, 'data.result': {'$eq': True}, - 'data.machine.ip_addr': {'$in': monkey_json['ip_addresses']}})] + 'data.machine.ip_addr': {'$in': monkey_json['ip_addresses']}})) if 1 == len(exploit_telem): parent_to_add = (exploit_telem[0].get('monkey_guid'), exploit_telem[0].get('data').get('exploiter')) diff --git a/monkey/monkey_island/cc/services/edge/displayed_edge.py b/monkey/monkey_island/cc/services/edge/displayed_edge.py index f7a0664bf..9b9509ea6 100644 --- a/monkey/monkey_island/cc/services/edge/displayed_edge.py +++ b/monkey/monkey_island/cc/services/edge/displayed_edge.py @@ -63,7 +63,7 @@ class DisplayedEdgeService: @staticmethod def services_to_displayed_services(services, for_report=False): if for_report: - return [x for x in services] + return list(services) else: return [x + ": " + (services[x]['name'] if 'name' in services[x] else 'unknown') for x in services] diff --git a/monkey/monkey_island/cc/services/telemetry/processing/scan.py b/monkey/monkey_island/cc/services/telemetry/processing/scan.py index 43446126c..70675c995 100644 --- a/monkey/monkey_island/cc/services/telemetry/processing/scan.py +++ b/monkey/monkey_island/cc/services/telemetry/processing/scan.py @@ -1,6 +1,5 @@ from monkey_island.cc.database import mongo from monkey_island.cc.models import Monkey -from monkey_island.cc.services.edge.edge import EdgeService from monkey_island.cc.services.node import NodeService from monkey_island.cc.services.telemetry.processing.utils import \ get_edge_by_scan_or_exploit_telemetry From 079fa58d0a0c82076f6001ef4937a5364444e337 Mon Sep 17 00:00:00 2001 From: "deepsource-autofix[bot]" <62050782+deepsource-autofix[bot]@users.noreply.github.com> Date: Fri, 4 Dec 2020 17:47:53 +0000 Subject: [PATCH 24/73] Autofixes made using DeepSource --- monkey/infection_monkey/exploit/shellshock.py | 1 - monkey/infection_monkey/exploit/web_rce.py | 2 +- monkey/infection_monkey/network/network_scanner.py | 2 +- monkey/infection_monkey/network/tools.py | 2 +- .../windows_cred_collector/pypykatz_handler.py | 4 ++-- .../utils/plugins/pluginTests/BadImport.py | 2 -- monkey/monkey_island/cc/resources/monkey.py | 10 ++++------ .../monkey_island/cc/services/edge/displayed_edge.py | 2 +- .../cc/services/telemetry/processing/scan.py | 1 - 9 files changed, 10 insertions(+), 16 deletions(-) diff --git a/monkey/infection_monkey/exploit/shellshock.py b/monkey/infection_monkey/exploit/shellshock.py index f9548b6bf..edec8018e 100644 --- a/monkey/infection_monkey/exploit/shellshock.py +++ b/monkey/infection_monkey/exploit/shellshock.py @@ -228,7 +228,6 @@ class ShellShockExploiter(HostExploiter): Checks if which urls exist :return: Sequence of URLs to try and attack """ - import requests attack_path = 'http://' if is_https: attack_path = 'https://' diff --git a/monkey/infection_monkey/exploit/web_rce.py b/monkey/infection_monkey/exploit/web_rce.py index 0f489d0a6..f5db3e92f 100644 --- a/monkey/infection_monkey/exploit/web_rce.py +++ b/monkey/infection_monkey/exploit/web_rce.py @@ -56,7 +56,7 @@ class WebRCE(HostExploiter): Method that creates a dictionary of configuration values for exploit :return: configuration dict """ - exploit_config = dict() + exploit_config = {} # dropper: If true monkey will use dropper parameter that will detach monkey's process and try to copy # it's file to the default destination path. diff --git a/monkey/infection_monkey/network/network_scanner.py b/monkey/infection_monkey/network/network_scanner.py index 6abf409ad..95277b4b9 100644 --- a/monkey/infection_monkey/network/network_scanner.py +++ b/monkey/infection_monkey/network/network_scanner.py @@ -113,7 +113,7 @@ class NetworkScanner(object): :return: Victim or None if victim isn't alive """ LOG.debug("Scanning target address: %r", victim) - if any([scanner.is_host_alive(victim) for scanner in self.scanners]): + if any(scanner.is_host_alive(victim) for scanner in self.scanners): LOG.debug("Found potential target_ip: %r", victim) return victim else: diff --git a/monkey/infection_monkey/network/tools.py b/monkey/infection_monkey/network/tools.py index 049b30838..99b21d81c 100644 --- a/monkey/infection_monkey/network/tools.py +++ b/monkey/infection_monkey/network/tools.py @@ -139,7 +139,7 @@ def check_tcp_ports(ip, ports, timeout=DEFAULT_TIMEOUT, get_banner=False): timeout = int(round(timeout)) # clamp to integer, to avoid checking input sockets_to_try = possible_ports[:] connected_ports_sockets = [] - while (timeout >= 0) and len(sockets_to_try): + while (timeout >= 0) and sockets_to_try: sock_objects = [s[1] for s in sockets_to_try] _, writeable_sockets, _ = select.select(sock_objects, sock_objects, sock_objects, 0) diff --git a/monkey/infection_monkey/system_info/windows_cred_collector/pypykatz_handler.py b/monkey/infection_monkey/system_info/windows_cred_collector/pypykatz_handler.py index cba4c330a..35ff67678 100644 --- a/monkey/infection_monkey/system_info/windows_cred_collector/pypykatz_handler.py +++ b/monkey/infection_monkey/system_info/windows_cred_collector/pypykatz_handler.py @@ -67,8 +67,8 @@ def _get_windows_cred(pypykatz_cred: PypykatzCredential): def _hash_to_string(hash_: Any): - if type(hash_) == str: + if type(hash_) is str: return hash_ - if type(hash_) == bytes: + if type(hash_) is bytes: return binascii.hexlify(bytearray(hash_)).decode() raise Exception(f"Can't convert hash_ to string, unsupported hash_ type {type(hash_)}") diff --git a/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py b/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py index d28a91a89..1377d75be 100644 --- a/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py +++ b/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py @@ -1,5 +1,3 @@ -from infection_monkey.utils.plugins.pluginTests.PluginTestClass import \ - TestPlugin # noqa: F401 class SomeDummyPlugin: diff --git a/monkey/monkey_island/cc/resources/monkey.py b/monkey/monkey_island/cc/resources/monkey.py index 0962e6dd5..cd570903d 100644 --- a/monkey/monkey_island/cc/resources/monkey.py +++ b/monkey/monkey_island/cc/resources/monkey.py @@ -87,20 +87,18 @@ class Monkey(flask_restful.Resource): parent = monkey_json.get('parent') parent_to_add = (monkey_json.get('guid'), None) # default values in case of manual run if parent and parent != monkey_json.get('guid'): # current parent is known - exploit_telem = [x for x in - mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, + exploit_telem = list(mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, 'data.result': {'$eq': True}, 'data.machine.ip_addr': {'$in': monkey_json['ip_addresses']}, - 'monkey_guid': {'$eq': parent}})] + 'monkey_guid': {'$eq': parent}})) if 1 == len(exploit_telem): parent_to_add = (exploit_telem[0].get('monkey_guid'), exploit_telem[0].get('data').get('exploiter')) else: parent_to_add = (parent, None) elif (not parent or parent == monkey_json.get('guid')) and 'ip_addresses' in monkey_json: - exploit_telem = [x for x in - mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, + exploit_telem = list(mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, 'data.result': {'$eq': True}, - 'data.machine.ip_addr': {'$in': monkey_json['ip_addresses']}})] + 'data.machine.ip_addr': {'$in': monkey_json['ip_addresses']}})) if 1 == len(exploit_telem): parent_to_add = (exploit_telem[0].get('monkey_guid'), exploit_telem[0].get('data').get('exploiter')) diff --git a/monkey/monkey_island/cc/services/edge/displayed_edge.py b/monkey/monkey_island/cc/services/edge/displayed_edge.py index f7a0664bf..9b9509ea6 100644 --- a/monkey/monkey_island/cc/services/edge/displayed_edge.py +++ b/monkey/monkey_island/cc/services/edge/displayed_edge.py @@ -63,7 +63,7 @@ class DisplayedEdgeService: @staticmethod def services_to_displayed_services(services, for_report=False): if for_report: - return [x for x in services] + return list(services) else: return [x + ": " + (services[x]['name'] if 'name' in services[x] else 'unknown') for x in services] diff --git a/monkey/monkey_island/cc/services/telemetry/processing/scan.py b/monkey/monkey_island/cc/services/telemetry/processing/scan.py index 43446126c..70675c995 100644 --- a/monkey/monkey_island/cc/services/telemetry/processing/scan.py +++ b/monkey/monkey_island/cc/services/telemetry/processing/scan.py @@ -1,6 +1,5 @@ from monkey_island.cc.database import mongo from monkey_island.cc.models import Monkey -from monkey_island.cc.services.edge.edge import EdgeService from monkey_island.cc.services.node import NodeService from monkey_island.cc.services.telemetry.processing.utils import \ get_edge_by_scan_or_exploit_telemetry From 09d80e59a967676e0e3bd8c2dd5b290d35cf53ad Mon Sep 17 00:00:00 2001 From: shubhendra Date: Sat, 5 Dec 2020 01:32:45 +0530 Subject: [PATCH 25/73] Revert "Remove unused imports" This reverts commit 1c780a18fbea0414ef8f9c22c4265b547fc0668e. --- monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py b/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py index 1377d75be..d28a91a89 100644 --- a/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py +++ b/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py @@ -1,3 +1,5 @@ +from infection_monkey.utils.plugins.pluginTests.PluginTestClass import \ + TestPlugin # noqa: F401 class SomeDummyPlugin: From 9f48a54529a79756b96983f1c4ffba912a366377 Mon Sep 17 00:00:00 2001 From: Shubhendra Singh Chauhan Date: Sat, 5 Dec 2020 01:53:21 +0530 Subject: [PATCH 26/73] Update BadImport.py --- monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py b/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py index 1377d75be..d28a91a89 100644 --- a/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py +++ b/monkey/infection_monkey/utils/plugins/pluginTests/BadImport.py @@ -1,3 +1,5 @@ +from infection_monkey.utils.plugins.pluginTests.PluginTestClass import \ + TestPlugin # noqa: F401 class SomeDummyPlugin: From 32593b2105bc0dba7e6f7c3275faa946a4ae98c0 Mon Sep 17 00:00:00 2001 From: shubhendra Date: Sat, 5 Dec 2020 14:24:49 +0530 Subject: [PATCH 27/73] revert-Remove unnecessary use of comprehension --- monkey/monkey_island/cc/resources/monkey.py | 10 ++++++---- .../monkey_island/cc/services/edge/displayed_edge.py | 2 +- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/monkey/monkey_island/cc/resources/monkey.py b/monkey/monkey_island/cc/resources/monkey.py index cd570903d..0962e6dd5 100644 --- a/monkey/monkey_island/cc/resources/monkey.py +++ b/monkey/monkey_island/cc/resources/monkey.py @@ -87,18 +87,20 @@ class Monkey(flask_restful.Resource): parent = monkey_json.get('parent') parent_to_add = (monkey_json.get('guid'), None) # default values in case of manual run if parent and parent != monkey_json.get('guid'): # current parent is known - exploit_telem = list(mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, + exploit_telem = [x for x in + mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, 'data.result': {'$eq': True}, 'data.machine.ip_addr': {'$in': monkey_json['ip_addresses']}, - 'monkey_guid': {'$eq': parent}})) + 'monkey_guid': {'$eq': parent}})] if 1 == len(exploit_telem): parent_to_add = (exploit_telem[0].get('monkey_guid'), exploit_telem[0].get('data').get('exploiter')) else: parent_to_add = (parent, None) elif (not parent or parent == monkey_json.get('guid')) and 'ip_addresses' in monkey_json: - exploit_telem = list(mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, + exploit_telem = [x for x in + mongo.db.telemetry.find({'telem_category': {'$eq': 'exploit'}, 'data.result': {'$eq': True}, - 'data.machine.ip_addr': {'$in': monkey_json['ip_addresses']}})) + 'data.machine.ip_addr': {'$in': monkey_json['ip_addresses']}})] if 1 == len(exploit_telem): parent_to_add = (exploit_telem[0].get('monkey_guid'), exploit_telem[0].get('data').get('exploiter')) diff --git a/monkey/monkey_island/cc/services/edge/displayed_edge.py b/monkey/monkey_island/cc/services/edge/displayed_edge.py index 9b9509ea6..f7a0664bf 100644 --- a/monkey/monkey_island/cc/services/edge/displayed_edge.py +++ b/monkey/monkey_island/cc/services/edge/displayed_edge.py @@ -63,7 +63,7 @@ class DisplayedEdgeService: @staticmethod def services_to_displayed_services(services, for_report=False): if for_report: - return list(services) + return [x for x in services] else: return [x + ": " + (services[x]['name'] if 'name' in services[x] else 'unknown') for x in services] From 816c1089de641e163635516a3530e7c53d5a0d27 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Tue, 8 Dec 2020 16:08:59 +0200 Subject: [PATCH 28/73] Clarified password reset procedure, especially the part abaout leaving deployment option unchanged --- docs/content/FAQ/_index.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/docs/content/FAQ/_index.md b/docs/content/FAQ/_index.md index 85e751259..f76c0f3b1 100644 --- a/docs/content/FAQ/_index.md +++ b/docs/content/FAQ/_index.md @@ -41,7 +41,8 @@ The Monkey shuts off either when it can't find new victims, or when it has excee On your first access of Monkey Island server, you'll be prompted to create an account. If you forgot the credentials you entered or just want to change them, you need to manually alter the `server_config.json` file. On Linux, this file is located on `/var/monkey/monkey_island/cc/server_config.json`. On windows, it's based on your install directory (typically - `C:\Program Files\Guardicore\Monkey Island\monkey_island\cc\server_config.json`). Reset the contents of this file back to + `C:\Program Files\Guardicore\Monkey Island\monkey_island\cc\server_config.json`). Reset the contents of this file + leaving the **deployment option unchanged** (it might be "vmware" or "linux" in your case): ```json { @@ -49,9 +50,8 @@ On your first access of Monkey Island server, you'll be prompted to create an ac "deployment": "windows" } ``` -Leave the deployment option unchanged (it might be "vmware" or "linux" in your case). Then reset the Island process -(`sudo systemctl restart monkey-island.service` for linux, restart program for windows). Go to the island's URL and create -a new account. + Then reset the Island process (`sudo systemctl restart monkey-island.service` for linux, restart program for windows). + Finally, go to the Island's URL and create a new account. ## Should I run the Monkey continuously? From 330ad6540e16b74fcce7f7d29aed08eedef62771 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 8 Dec 2020 08:45:49 -0500 Subject: [PATCH 29/73] Check if user is root before starting deploy_linux script If the user is root, we want to exit as soon as possible since any commands that the deployment script runs will be run as root. --- deployment_scripts/deploy_linux.sh | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/deployment_scripts/deploy_linux.sh b/deployment_scripts/deploy_linux.sh index d13478018..1f21fb758 100755 --- a/deployment_scripts/deploy_linux.sh +++ b/deployment_scripts/deploy_linux.sh @@ -23,6 +23,11 @@ log_message() { echo -e "DEPLOYMENT SCRIPT: $1" } +if is_root; then + log_message "Please don't run this script as root" + exit 1 +fi + config_branch=${2:-"develop"} config_url="https://raw.githubusercontent.com/guardicore/monkey/${config_branch}/deployment_scripts/config" @@ -62,11 +67,6 @@ ISLAND_BINARIES_PATH="$ISLAND_PATH/cc/binaries" INFECTION_MONKEY_DIR="$monkey_home/monkey/infection_monkey" MONKEY_BIN_DIR="$INFECTION_MONKEY_DIR/bin" -if is_root; then - log_message "Please don't run this script as root" - exit 1 -fi - HAS_SUDO=$(has_sudo) if [[ ! $HAS_SUDO ]]; then log_message "You need root permissions for some of this script operations. Quiting." From 6f0fffee078bd0e376346f742bff795362e36302 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 8 Dec 2020 10:01:36 -0500 Subject: [PATCH 30/73] Fix hung timeout when checking for sudo in deploy_linux.sh --- deployment_scripts/deploy_linux.sh | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/deployment_scripts/deploy_linux.sh b/deployment_scripts/deploy_linux.sh index 1f21fb758..cea8d70a8 100755 --- a/deployment_scripts/deploy_linux.sh +++ b/deployment_scripts/deploy_linux.sh @@ -10,7 +10,7 @@ is_root() { has_sudo() { # 0 true, 1 false - timeout 1 sudo id && return 0 || return 1 + return $(sudo -nv > /dev/null 2>&1) } handle_error() { @@ -67,8 +67,7 @@ ISLAND_BINARIES_PATH="$ISLAND_PATH/cc/binaries" INFECTION_MONKEY_DIR="$monkey_home/monkey/infection_monkey" MONKEY_BIN_DIR="$INFECTION_MONKEY_DIR/bin" -HAS_SUDO=$(has_sudo) -if [[ ! $HAS_SUDO ]]; then +if ! has_sudo; then log_message "You need root permissions for some of this script operations. Quiting." exit 1 fi From 0238354bea6e06d91038b19d0cc56d1106ad3006 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 8 Dec 2020 10:23:53 -0500 Subject: [PATCH 31/73] Give a more descriptive error message if deploy_linux.sh cannot use sudo --- deployment_scripts/deploy_linux.sh | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/deployment_scripts/deploy_linux.sh b/deployment_scripts/deploy_linux.sh index cea8d70a8..f11e126da 100755 --- a/deployment_scripts/deploy_linux.sh +++ b/deployment_scripts/deploy_linux.sh @@ -68,7 +68,8 @@ INFECTION_MONKEY_DIR="$monkey_home/monkey/infection_monkey" MONKEY_BIN_DIR="$INFECTION_MONKEY_DIR/bin" if ! has_sudo; then - log_message "You need root permissions for some of this script operations. Quiting." + log_message "You need root permissions for some of this script operations. \ +Run \`sudo -v\`, enter your password, and then re-run this script." exit 1 fi From 88c7a6a0f9a559c1e5eacd14d88beac64ac2430c Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Mon, 5 Oct 2020 10:24:37 +0300 Subject: [PATCH 32/73] Fixed linux deployment script config to point to proper repository --- deployment_scripts/config | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/deployment_scripts/config b/deployment_scripts/config index bda54e390..2dbeaf442 100644 --- a/deployment_scripts/config +++ b/deployment_scripts/config @@ -10,7 +10,7 @@ get_latest_release() { sed -E 's/.*"([^"]+)".*/\1/' # Pluck JSON value } -MONKEY_LATEST_RELEASE=$(get_latest_release "monkey/guardicore") +MONKEY_LATEST_RELEASE=$(get_latest_release "guardicore/monkey") # Monkey binaries LINUX_32_BINARY_NAME="monkey-linux-32" From b84d1f1708e2adff8139c13a7da958c4e08b8f69 Mon Sep 17 00:00:00 2001 From: VakarisZ Date: Mon, 5 Oct 2020 10:28:45 +0300 Subject: [PATCH 33/73] Fixed linux deployment script config syntax --- deployment_scripts/config | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/deployment_scripts/config b/deployment_scripts/config index 2dbeaf442..5d645a28f 100644 --- a/deployment_scripts/config +++ b/deployment_scripts/config @@ -14,31 +14,31 @@ MONKEY_LATEST_RELEASE=$(get_latest_release "guardicore/monkey") # Monkey binaries LINUX_32_BINARY_NAME="monkey-linux-32" -LINUX_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$($MONKEY_LATEST_RELEASE)/monkey-linux-32" +LINUX_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-linux-32" export LINUX_32_BINARY_URL export LINUX_32_BINARY_NAME LINUX_64_BINARY_NAME="monkey-linux-64" -LINUX_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$($MONKEY_LATEST_RELEASE)/monkey-linux-64" +LINUX_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-linux-64" export LINUX_64_BINARY_URL export LINUX_64_BINARY_NAME WINDOWS_32_BINARY_NAME="monkey-windows-32.exe" -WINDOWS_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$($MONKEY_LATEST_RELEASE)/monkey-windows-32.exe" +WINDOWS_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-windows-32.exe" export WINDOWS_32_BINARY_URL export WINDOWS_32_BINARY_NAME WINDOWS_64_BINARY_NAME="monkey-windows-64.exe" -WINDOWS_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$($MONKEY_LATEST_RELEASE)/monkey-windows-64.exe" +WINDOWS_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-windows-64.exe" export WINDOWS_64_BINARY_URL export WINDOWS_64_BINARY_NAME # Other binaries for monkey -TRACEROUTE_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$($MONKEY_LATEST_RELEASE)/traceroute64" +TRACEROUTE_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/traceroute64" export TRACEROUTE_64_BINARY_URL -TRACEROUTE_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$($MONKEY_LATEST_RELEASE)/traceroute32" +TRACEROUTE_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/traceroute32" export TRACEROUTE_32_BINARY_URL -SAMBACRY_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$($MONKEY_LATEST_RELEASE)/sc_monkey_runner64.so" +SAMBACRY_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/sc_monkey_runner64.so" export SAMBACRY_64_BINARY_URL -SAMBACRY_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$($MONKEY_LATEST_RELEASE)/sc_monkey_runner32.so" +SAMBACRY_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/sc_monkey_runner32.so" export SAMBACRY_32_BINARY_URL From c807104a3815bbf630ff3aa26615c680b56ff81a Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 8 Dec 2020 12:25:41 -0500 Subject: [PATCH 34/73] Enable deployment_scripts/config to use wget or curl --- deployment_scripts/config | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/deployment_scripts/config b/deployment_scripts/config index 5d645a28f..f5e4e5d88 100644 --- a/deployment_scripts/config +++ b/deployment_scripts/config @@ -4,10 +4,22 @@ export MONKEY_FOLDER_NAME="infection_monkey" # Url of public git repository that contains monkey's source code export MONKEY_GIT_URL="https://github.com/guardicore/monkey" +exists() { + command -v "$1" >/dev/null 2>&1 +} + get_latest_release() { - curl --silent "https://api.github.com/repos/$1/releases/latest" | # Get latest release from GitHub API - grep '"tag_name":' | # Get tag line - sed -E 's/.*"([^"]+)".*/\1/' # Pluck JSON value + RELEASE_URL="https://api.github.com/repos/$1/releases/latest" + + if exists wget; then + RELEASE_INFO=$(wget --quiet -O - "$RELEASE_URL") # Get latest release from GitHub API + else + RELEASE_INFO=$(curl --silent "$RELEASE_URL") # Get latest release from GitHub API + fi + + echo "$RELEASE_INFO" | + grep '"tag_name":' | # Get tag line + sed -E 's/.*"([^"]+)".*/\1/' # Pluck JSON value } MONKEY_LATEST_RELEASE=$(get_latest_release "guardicore/monkey") From 39da1299333d59204fd90c9348fae8ae74144d7c Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 8 Dec 2020 12:38:04 -0500 Subject: [PATCH 35/73] Install python3-distutils in deploy_linux.sh --- deployment_scripts/deploy_linux.sh | 3 +++ 1 file changed, 3 insertions(+) diff --git a/deployment_scripts/deploy_linux.sh b/deployment_scripts/deploy_linux.sh index f11e126da..2dcccd02d 100755 --- a/deployment_scripts/deploy_linux.sh +++ b/deployment_scripts/deploy_linux.sh @@ -118,6 +118,9 @@ fi log_message "Installing build-essential" sudo apt install build-essential +log_message "Installing python3-distutils" +sudo apt install python3-distutils + log_message "Installing or updating pip" # shellcheck disable=SC2086 pip_url=https://bootstrap.pypa.io/get-pip.py From cdc65152d268f58fbbd40b6d9219f6e7b88138c6 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 8 Dec 2020 12:39:07 -0500 Subject: [PATCH 36/73] Make create_certificate.sh executible when deploying on linux --- deployment_scripts/deploy_linux.sh | 1 + 1 file changed, 1 insertion(+) diff --git a/deployment_scripts/deploy_linux.sh b/deployment_scripts/deploy_linux.sh index 2dcccd02d..044e95bd2 100755 --- a/deployment_scripts/deploy_linux.sh +++ b/deployment_scripts/deploy_linux.sh @@ -174,6 +174,7 @@ sudo apt-get install openssl # Generate SSL certificate log_message "Generating certificate" +chmod u+x "${ISLAND_PATH}"/linux/create_certificate.sh "${ISLAND_PATH}"/linux/create_certificate.sh ${ISLAND_PATH}/cc # Update node From 66ac438fa263c85e80790d98c2e4f9a4cc03d885 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 8 Dec 2020 13:50:33 -0500 Subject: [PATCH 37/73] Install libcurl4 in deploy_linux.sh --- deployment_scripts/deploy_linux.sh | 3 +++ 1 file changed, 3 insertions(+) diff --git a/deployment_scripts/deploy_linux.sh b/deployment_scripts/deploy_linux.sh index 044e95bd2..9c73cbe03 100755 --- a/deployment_scripts/deploy_linux.sh +++ b/deployment_scripts/deploy_linux.sh @@ -165,6 +165,9 @@ chmod a+x "$ISLAND_BINARIES_PATH/$LINUX_64_BINARY_NAME" # If a user haven't installed mongo manually check if we can install it with our script if ! exists mongod; then + log_message "Installing libcurl4" + sudo apt install libcurl4 + log_message "Installing MongoDB" "${ISLAND_PATH}"/linux/install_mongo.sh ${MONGO_PATH} || handle_error fi From ce40392c2bd9534769036fea5961441e3f5fc96b Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 8 Dec 2020 14:25:14 -0500 Subject: [PATCH 38/73] Assume yes for `apt install` commands in deploy_linux.sh --- deployment_scripts/deploy_linux.sh | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/deployment_scripts/deploy_linux.sh b/deployment_scripts/deploy_linux.sh index 9c73cbe03..c037881c4 100755 --- a/deployment_scripts/deploy_linux.sh +++ b/deployment_scripts/deploy_linux.sh @@ -110,16 +110,16 @@ if [[ ${python_cmd} == "" ]]; then log_message "Python 3.7 command not found. Installing python 3.7." sudo add-apt-repository ppa:deadsnakes/ppa sudo apt-get update - sudo apt install python3.7 python3.7-dev + sudo apt install -y python3.7 python3.7-dev log_message "Python 3.7 is now available with command 'python3.7'." python_cmd="python3.7" fi log_message "Installing build-essential" -sudo apt install build-essential +sudo apt install -y build-essential log_message "Installing python3-distutils" -sudo apt install python3-distutils +sudo apt install -y python3-distutils log_message "Installing or updating pip" # shellcheck disable=SC2086 @@ -137,7 +137,7 @@ requirements_island="$ISLAND_PATH/requirements.txt" ${python_cmd} -m pip install -r "${requirements_island}" --user --upgrade || handle_error log_message "Installing monkey requirements" -sudo apt-get install libffi-dev upx libssl-dev libc++1 +sudo apt install -y libffi-dev upx libssl-dev libc++1 requirements_monkey="$INFECTION_MONKEY_DIR/requirements.txt" ${python_cmd} -m pip install -r "${requirements_monkey}" --user --upgrade || handle_error @@ -166,13 +166,13 @@ chmod a+x "$ISLAND_BINARIES_PATH/$LINUX_64_BINARY_NAME" # If a user haven't installed mongo manually check if we can install it with our script if ! exists mongod; then log_message "Installing libcurl4" - sudo apt install libcurl4 + sudo apt install -y libcurl4 log_message "Installing MongoDB" "${ISLAND_PATH}"/linux/install_mongo.sh ${MONGO_PATH} || handle_error fi log_message "Installing openssl" -sudo apt-get install openssl +sudo apt install -y openssl # Generate SSL certificate log_message "Generating certificate" @@ -189,7 +189,7 @@ if ! exists npm; then else wget -q -O - $node_src | sudo -E bash - fi - sudo apt-get install -y nodejs + sudo apt install -y nodejs fi pushd "$ISLAND_PATH/cc/ui" || handle_error From 2111d2af697ae0276c9b1b5aeb17eab0a4498c25 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 8 Dec 2020 14:40:20 -0500 Subject: [PATCH 39/73] Add instructions on how to run monkey_island after deploy_linux.sh --- deployment_scripts/README.md | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/deployment_scripts/README.md b/deployment_scripts/README.md index 16b150852..4ee91b5b4 100644 --- a/deployment_scripts/README.md +++ b/deployment_scripts/README.md @@ -39,6 +39,7 @@ Your user must have root permissions; however, don't run the script as root! ```sh 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! @@ -52,4 +53,13 @@ After downloading that script, execute it in a shell. The first argument should - `./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. \ No newline at end of file +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. + +```sh +cd infection_monkey/monkey +./monkey_island/linux/run.sh +``` From 5401cf2406f1ec29e356089795c852151a82e7b1 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 8 Dec 2020 18:53:19 -0500 Subject: [PATCH 40/73] Switch from `apt install` to `apt-get install` in deploy_linux.sh `apt-get` has a stable command-line interface, while `apt` does not. --- deployment_scripts/deploy_linux.sh | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/deployment_scripts/deploy_linux.sh b/deployment_scripts/deploy_linux.sh index c037881c4..728e2f52d 100755 --- a/deployment_scripts/deploy_linux.sh +++ b/deployment_scripts/deploy_linux.sh @@ -110,16 +110,16 @@ if [[ ${python_cmd} == "" ]]; then log_message "Python 3.7 command not found. Installing python 3.7." sudo add-apt-repository ppa:deadsnakes/ppa sudo apt-get update - sudo apt install -y python3.7 python3.7-dev + sudo apt-get install -y python3.7 python3.7-dev log_message "Python 3.7 is now available with command 'python3.7'." python_cmd="python3.7" fi log_message "Installing build-essential" -sudo apt install -y build-essential +sudo apt-get install -y build-essential log_message "Installing python3-distutils" -sudo apt install -y python3-distutils +sudo apt-get install -y python3-distutils log_message "Installing or updating pip" # shellcheck disable=SC2086 @@ -137,7 +137,7 @@ requirements_island="$ISLAND_PATH/requirements.txt" ${python_cmd} -m pip install -r "${requirements_island}" --user --upgrade || handle_error log_message "Installing monkey requirements" -sudo apt install -y libffi-dev upx libssl-dev libc++1 +sudo apt-get install -y libffi-dev upx libssl-dev libc++1 requirements_monkey="$INFECTION_MONKEY_DIR/requirements.txt" ${python_cmd} -m pip install -r "${requirements_monkey}" --user --upgrade || handle_error @@ -166,13 +166,13 @@ chmod a+x "$ISLAND_BINARIES_PATH/$LINUX_64_BINARY_NAME" # If a user haven't installed mongo manually check if we can install it with our script if ! exists mongod; then log_message "Installing libcurl4" - sudo apt install -y libcurl4 + sudo apt-get install -y libcurl4 log_message "Installing MongoDB" "${ISLAND_PATH}"/linux/install_mongo.sh ${MONGO_PATH} || handle_error fi log_message "Installing openssl" -sudo apt install -y openssl +sudo apt-get install -y openssl # Generate SSL certificate log_message "Generating certificate" @@ -189,7 +189,7 @@ if ! exists npm; then else wget -q -O - $node_src | sudo -E bash - fi - sudo apt install -y nodejs + sudo apt-get install -y nodejs fi pushd "$ISLAND_PATH/cc/ui" || handle_error From 61ebba274f4e211c52aad2224334e9ff61cd8cbe Mon Sep 17 00:00:00 2001 From: Shreya Date: Wed, 9 Dec 2020 21:45:30 +0530 Subject: [PATCH 41/73] =?UTF-8?q?Fix=20"Implement=20a=20new=20PBA=20?= =?UTF-8?q?=E2=80=94=20`ScheduleJobs`"=20Swimm=20unit,=20after=20changes?= =?UTF-8?q?=20in=20post=5Fbreach/actions/schedule=5Fjobs.py?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .swm/VW4rf3AxRslfT7lwaug7.swm | 53 +++++++++++++++++++++++------------ 1 file changed, 35 insertions(+), 18 deletions(-) diff --git a/.swm/VW4rf3AxRslfT7lwaug7.swm b/.swm/VW4rf3AxRslfT7lwaug7.swm index 65090e905..743079918 100644 --- a/.swm/VW4rf3AxRslfT7lwaug7.swm +++ b/.swm/VW4rf3AxRslfT7lwaug7.swm @@ -1,31 +1,48 @@ { "id": "VW4rf3AxRslfT7lwaug7", "name": "Implement a new PBA — `ScheduleJobs`", - "dod": "WW91JTIwc2hvdWxkJTIwaW1wbGVtZW50JTIwYSUyMG5ldyUyMFBCQSUyMGluJTIwTW9ua2V5JTIwd2hpY2glMjBzY2hlZHVsZXMlMjBqb2JzJTIwb24lMjB0aGUlMjBtYWNoaW5lLg==", - "description": "WW91JTIwbmVlZCUyMHRvJTIwaW1wbGVtZW50JTIwdGhlJTIwJTYwU2NoZWR1bGVKb2JzJTYwJTIwUEJBJTIwd2hpY2glMjBjcmVhdGVzJTIwc2NoZWR1bGVkJTIwam9icyUyMG9uJTIwdGhlJTIwbWFjaGluZS4lMjAlM0NiciUzRSUzQ2JyJTNFJTBBJTNDaW1nJTIwc3JjJTNEJTIyaHR0cHMlM0ElMkYlMkZtZWRpYS5naXBoeS5jb20lMkZtZWRpYSUyRmwwSzRtVkU1YjVXWjFzY3RXJTJGZ2lwaHkuZ2lmJTIyJTIwaGVpZ2h0JTNEMTc1JTNFJTNDYnIlM0UlM0NiciUzRSUwQVRoZSUyMGNvbW1hbmRzJTIwdGhhdCUyMGFkZCUyMHNjaGVkdWxlZCUyMGpvYnMlMjBmb3IlMjBXaW5kb3dzJTIwYW5kJTIwTGludXglMjBjYW4lMjBiZSUyMHJldHJpZXZlZCUyMGZyb20lMjAlNjBnZXRfY29tbWFuZHNfdG9fc2NoZWR1bGVfam9icyU2MCUyMCVFMiU4MCU5NCUyMG1ha2UlMjBzdXJlJTIweW91JTIwdW5kZXJzdGFuZCUyMGhvdyUyMHRvJTIwdXNlJTIwdGhpcyUyMGZ1bmN0aW9uJTIwY29ycmVjdGx5LiUwQSUwQSUyMyUyMyUyME1hbnVhbCUyMHRlc3QlMjAlMjAlMEFPbmNlJTIweW91JTIwdGhpbmslMjB5b3UncmUlMjBkb25lLi4uJTBBLSUyMFJ1biUyMHRoZSUyME1vbmtleSUyMElzbGFuZCUwQS0lMjBNYWtlJTIwc3VyZSUyMHRoZSUyMCUyMkpvYiUyMHNjaGVkdWxpbmclMjIlMjBQQkElMjBpcyUyMGVuYWJsZWQlMjBpbiUyMHRoZSUyMCUyMk1vbmtleSUyMiUyMHRhYiUyMGluJTIwdGhlJTIwY29uZmlndXJhdGlvbiUyMCVFMiU4MCU5NCUyMGZvciUyMHRoaXMlMjB0ZXN0JTJDJTIwZGlzYWJsZSUyMG5ldHdvcmslMjBzY2FubmluZyUyQyUyMGV4cGxvaXRpbmclMkMlMjBhbmQlMjBhbGwlMjBvdGhlciUyMFBCQXMlMEEtJTIwUnVuJTIwdGhlJTIwTW9ua2V5JTBBLSUyME1ha2UlMjBzdXJlJTIweW91JTIwc2VlJTIwdGhlJTIwUEJBJTIwd2l0aCUyMGl0cyUyMHJlc3VsdHMlMjBpbiUyMHRoZSUyMFNlY3VyaXR5JTIwcmVwb3J0JTIwYXMlMjB3ZWxsJTIwYXMlMjBpbiUyMHRoZSUyMEFUVCUyNkNLJTIwcmVwb3J0JTIwdW5kZXIlMjB0aGUlMjByZWxldmFudCUyME1JVFJFJTIwdGVjaG5pcXVlJTBBJTBBJTNDaW1nJTIwc3JjJTNEJTIyaHR0cHMlM0ElMkYlMkZmaXJlYmFzZXN0b3JhZ2UuZ29vZ2xlYXBpcy5jb20lMkZ2MCUyRmIlMkZzd2ltbWlvLWNvbnRlbnQlMkZvJTJGcmVwb3NpdG9yaWVzJTI1MkY2TmxiOTlOdFk1RmMzYlNkOHN1SCUyNTJGaW1nJTI1MkZmMGU1M2U2Yy05ZGJlLTQxZDgtOTQ1NC0yYjU3NjFjM2Y1M2EucG5nJTNGYWx0JTNEbWVkaWElMjZ0b2tlbiUzRDIxYWE0YmI4LTdlYmUtNGRhYi1hNzM5LWM3N2UwNTkxNDRkZCUyMiUyMGhlaWdodCUzRDQwMCUzRSUwQSUzQ2JyJTNFJTNDYnIlM0UlMEElM0NpbWclMjBzcmMlM0QlMjJodHRwcyUzQSUyRiUyRmZpcmViYXNlc3RvcmFnZS5nb29nbGVhcGlzLmNvbSUyRnYwJTJGYiUyRnN3aW1taW8tY29udGVudCUyRm8lMkZyZXBvc2l0b3JpZXMlMjUyRjZObGI5OU50WTVGYzNiU2Q4c3VIJTI1MkZpbWclMjUyRjUyODM4OWEwLTM1YzgtNDM4MC1iNmUyLTM1MzA2OGVkMDFlNC5wbmclM0ZhbHQlM0RtZWRpYSUyNnRva2VuJTNEMDg3NjdmNTUtODZlMi00ZjUxLThlY2YtMTNmZDZjYzI1YWQ1JTIyJTIwaGVpZ2h0JTNENDAwJTNF", - "summary": "TWFueSUyMG90aGVyJTIwUEJBcyUyMGFyZSUyMGFzJTIwc2ltcGxlJTIwYXMlMjB0aGlzJTIwb25lJTJDJTIwdXNpbmclMjBzaGVsbCUyMGNvbW1hbmRzJTIwb3IlMjBzY3JpcHRzJTIwJUUyJTgwJTk0JTIwc2VlJTIwJTYwVGltZXN0b21waW5nJTYwJTIwYW5kJTIwJTYwQWNjb3VudERpc2NvdmVyeSU2MC4lMjAlM0NiciUzRSUzQ2JyJTNFJTBBJTBBSG93ZXZlciUyQyUyMGZvciUyMGxlc3MlMjBzdHJhaWdodGZvcndhcmQlMjBvbmVzJTJDJTIweW91JTIwY2FuJTIwb3ZlcnJpZGUlMjBmdW5jdGlvbnMlMjBhbmQlMjBpbXBsZW1lbnQlMjBuZXclMjBjbGFzc2VzJTIwZGVwZW5kaW5nJTIwb24lMjB3aGF0JTIwaXMlMjByZXF1aXJlZCUyMCVFMiU4MCU5NCUyMHNlZSUyMCU2MFNpZ25lZFNjcmlwdFByb3h5RXhlY3V0aW9uJTYwJTIwYW5kJTIwJTYwTW9kaWZ5U2hlbGxTdGFydHVwRmlsZXMlNjAuJTNDYnIlM0UlM0NiciUzRSUwQSUwQVRoaXMlMjBQQkElMkMlMjBhbG9uZyUyMHdpdGglMjBhbGwlMjB0aGUlMjBvdGhlciUyMFBCQXMlMkMlMjB3aWxsJTIwcnVuJTIwb24lMjBhJTIwc3lzdGVtJTIwYWZ0ZXIlMjBpdCUyMGhhcyUyMGJlZW4lMjBicmVhY2hlZC4lMjBUaGUlMjBwdXJwb3NlJTIwb2YlMjB0aGlzJTIwY29kZSUyMGlzJTIwdG8lMjB0ZXN0JTIwd2hldGhlciUyMHRhcmdldCUyMHN5c3RlbXMlMjBhbGxvdyUyMGF0dGFja2VycyUyMHRvJTIwc2NoZWR1bGUlMjBqb2JzJTJDJTIwd2hpY2glMjB0aGV5JTIwY291bGQlMjB1c2UlMjB0byUyMHJ1biUyMG1hbGljaW91cyUyMGNvZGUlMjBhdCUyMHNvbWUlMjBzcGVjaWZpZWQlMjBkYXRlJTIwYW5kJTIwdGltZS4=", - "diff": "ZGlmZiUyMC0tZ2l0JTIwYSUyRm1vbmtleSUyRmluZmVjdGlvbl9tb25rZXklMkZwb3N0X2JyZWFjaCUyRmFjdGlvbnMlMkZzY2hlZHVsZV9qb2JzLnB5JTIwYiUyRm1vbmtleSUyRmluZmVjdGlvbl9tb25rZXklMkZwb3N0X2JyZWFjaCUyRmFjdGlvbnMlMkZzY2hlZHVsZV9qb2JzLnB5JTBBaW5kZXglMjBkNmNkZDI3Ni4uNzlhNzcyNGQlMjAxMDA2NDQlMEEtLS0lMjBhJTJGbW9ua2V5JTJGaW5mZWN0aW9uX21vbmtleSUyRnBvc3RfYnJlYWNoJTJGYWN0aW9ucyUyRnNjaGVkdWxlX2pvYnMucHklMEElMkIlMkIlMkIlMjBiJTJGbW9ua2V5JTJGaW5mZWN0aW9uX21vbmtleSUyRnBvc3RfYnJlYWNoJTJGYWN0aW9ucyUyRnNjaGVkdWxlX2pvYnMucHklMEElNDAlNDAlMjAtMTAlMkMxMCUyMCUyQjEwJTJDNSUyMCU0MCU0MCUyMGNsYXNzJTIwU2NoZWR1bGVKb2JzKFBCQSklM0ElMEElMjAlMjAlMjAlMjAlMjAlMjIlMjIlMjIlMEElMjAlMEElMjAlMjAlMjAlMjAlMjBkZWYlMjBfX2luaXRfXyhzZWxmKSUzQSUwQS0lMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjBsaW51eF9jbWRzJTJDJTIwd2luZG93c19jbWRzJTIwJTNEJTIwZ2V0X2NvbW1hbmRzX3RvX3NjaGVkdWxlX2pvYnMoKSUwQS0lMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwc3VwZXIoU2NoZWR1bGVKb2JzJTJDJTIwc2VsZikuX19pbml0X18obmFtZSUzRFBPU1RfQlJFQUNIX0pPQl9TQ0hFRFVMSU5HJTJDJTBBLSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMGxpbnV4X2NtZCUzRCclMjAnLmpvaW4obGludXhfY21kcyklMkMlMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwd2luZG93c19jbWQlM0R3aW5kb3dzX2NtZHMpJTBBLSUwQS0lMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjByZW1vdmVfc2NoZWR1bGVkX2pvYnMoKSUwQSUyQiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMHBhc3MlMEElMkIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjMlMjBTd2ltbWVyJTNBJTIwSU1QTEVNRU5UJTIwSEVSRSElMEE=", + "dod": "You should implement a new PBA in Monkey which schedules jobs on the machine.", + "description": "You need to implement the `ScheduleJobs` PBA which creates scheduled jobs on the machine.

\n

\nThe commands that add scheduled jobs for Windows and Linux can be retrieved from `get_commands_to_schedule_jobs` — make sure you understand how to use this function correctly.\n\n## Manual test \nOnce you think you're done...\n- Run the Monkey Island\n- Make sure the \"Job scheduling\" PBA is enabled in the \"Monkey\" tab in the configuration — for this test, disable network scanning, exploiting, and all other PBAs\n- Run the Monkey\n- Make sure you see the PBA with its results in the Security report as well as in the ATT&CK report under the relevant MITRE technique\n\n\n

\n", + "summary": "Many other PBAs are as simple as this one, using shell commands or scripts — see `Timestomping` and `AccountDiscovery`.

\n\nHowever, for less straightforward ones, you can override functions and implement new classes depending on what is required — see `SignedScriptProxyExecution` and `ModifyShellStartupFiles`.

\n\nThis PBA, along with all the other PBAs, will run on a system after it has been breached. The purpose of this code is to test whether target systems allow attackers to schedule jobs, which they could use to run malicious code at some specified date and time.", + "diff": "diff --git a/monkey/infection_monkey/post_breach/actions/schedule_jobs.py b/monkey/infection_monkey/post_breach/actions/schedule_jobs.py\nindex d6cdd276..79a7724d 100644\n--- a/monkey/infection_monkey/post_breach/actions/schedule_jobs.py\n+++ b/monkey/infection_monkey/post_breach/actions/schedule_jobs.py\n@@ -10,11 +10,5 @@\n \"\"\"\n \n def __init__(self):\n- linux_cmds, windows_cmds = get_commands_to_schedule_jobs()\n+ pass\n-\n+ # Swimmer: IMPLEMENT HERE!\n- super(ScheduleJobs, self).__init__(name=POST_BREACH_JOB_SCHEDULING,\n- linux_cmd=' '.join(linux_cmds),\n- windows_cmd=windows_cmds)\n- \n- def run(self):\n- super(ScheduleJobs, self).run()\n", "tests": [], "hints": [ "Check out the `Timestomping` PBA to get an idea about the implementation.", "Don't forget to add code to remove the scheduled jobs!" ], - "files": { + "app_version": "0.2.8", + "file_version": "1.0.4", + "swimmPatch": { "monkey/infection_monkey/post_breach/actions/schedule_jobs.py": { - "index": [ - "d6cdd276..79a7724d", - "100644" - ], - "fileA": "monkey/infection_monkey/post_breach/actions/schedule_jobs.py", - "fileB": "monkey/infection_monkey/post_breach/actions/schedule_jobs.py", - "status": "MODIFIED", - "numLineDeletions": 7, - "numLineAdditions": 2, - "hunkContainers": [ - "JTdCJTIyaHVuayUyMiUzQSU3QiUyMmhlYWRlciUyMiUzQSUyMiU0MCU0MCUyMC0xMCUyQzEwJTIwJTJCMTAlMkM1JTIwJTQwJTQwJTIwY2xhc3MlMjBTY2hlZHVsZUpvYnMoUEJBKSUzQSUyMiUyQyUyMmNoYW5nZXMlMjIlM0ElNUIlN0IlMjJ0eXBlJTIyJTNBJTIyY29udGV4dCUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlNUMlMjIlNUMlMjIlNUMlMjIlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExMCUyQyUyMmIlMjIlM0ExMCU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTExJTJDJTIyYiUyMiUzQTExJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmNvbnRleHQlMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwZGVmJTIwX19pbml0X18oc2VsZiklM0ElMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExMiUyQyUyMmIlMjIlM0ExMiU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJkZWwlMjIlMkMlMjJtYXJrJTIyJTNBJTIyLSUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjBsaW51eF9jbWRzJTJDJTIwd2luZG93c19jbWRzJTIwJTNEJTIwZ2V0X2NvbW1hbmRzX3RvX3NjaGVkdWxlX2pvYnMoKSUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTEzJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTE0JTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMHN1cGVyKFNjaGVkdWxlSm9icyUyQyUyMHNlbGYpLl9faW5pdF9fKG5hbWUlM0RQT1NUX0JSRUFDSF9KT0JfU0NIRURVTElORyUyQyUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTE1JTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMGxpbnV4X2NtZCUzRCclMjAnLmpvaW4obGludXhfY21kcyklMkMlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExNiU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJkZWwlMjIlMkMlMjJtYXJrJTIyJTNBJTIyLSUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjB3aW5kb3dzX2NtZCUzRHdpbmRvd3NfY21kcyklMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExNyU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJkZWwlMjIlMkMlMjJtYXJrJTIyJTNBJTIyLSUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExOCU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJkZWwlMjIlMkMlMjJtYXJrJTIyJTNBJTIyLSUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjByZW1vdmVfc2NoZWR1bGVkX2pvYnMoKSUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTE5JTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmFkZCUyMiUyQyUyMm1hcmslMjIlM0ElMjIlMkIlMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwcGFzcyUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYiUyMiUzQTEzJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmFkZCUyMiUyQyUyMm1hcmslMjIlM0ElMjIlMkIlMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIzJTIwU3dpbW1lciUzQSUyMElNUExFTUVOVCUyMEhFUkUhJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJiJTIyJTNBMTQlN0QlN0QlNUQlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ElN0IlMjJzdGFydExpbmUlMjIlM0ExMCUyQyUyMmxpbmVzQ291bnQlMjIlM0ExMCU3RCUyQyUyMmIlMjIlM0ElN0IlMjJzdGFydExpbmUlMjIlM0ExMCUyQyUyMmxpbmVzQ291bnQlMjIlM0E1JTdEJTdEJTdEJTdE" + "diffType": "MODIFIED", + "fileDiffHeader": "diff --git a/monkey/infection_monkey/post_breach/actions/schedule_jobs.py b/monkey/infection_monkey/post_breach/actions/schedule_jobs.py\nindex d6cdd276..79a7724d 100644\n--- a/monkey/infection_monkey/post_breach/actions/schedule_jobs.py\n+++ b/monkey/infection_monkey/post_breach/actions/schedule_jobs.py", + "hunks": [ + { + "swimmHunkMetadata": { + "hunkComments": [] + }, + "hunkDiffLines": [ + "@@ -10,11 +10,5 @@", + " \"\"\"", + " ", + " def __init__(self):", + "- linux_cmds, windows_cmds = get_commands_to_schedule_jobs()", + "+ pass", + "-", + "+ # Swimmer: IMPLEMENT HERE!", + "- super(ScheduleJobs, self).__init__(name=POST_BREACH_JOB_SCHEDULING,", + "- linux_cmd=' '.join(linux_cmds),", + "- windows_cmd=windows_cmds)", + "- ", + "- def run(self):", + "- super(ScheduleJobs, self).run()" + ] + } ] } }, - "app_version": "0.1.90", - "file_version": "1.0.2" + "hunksOrder": [ + "monkey/infection_monkey/post_breach/actions/schedule_jobs.py_0" + ], + "last_commit_sha_for_swimm_patch": "44fd1ab69cfbab33cec638dcbbaa8831992a9a9f" } \ No newline at end of file From b78046e6f4d9e3db6b14e7b33d618946fad2a796 Mon Sep 17 00:00:00 2001 From: Shreya Date: Wed, 9 Dec 2020 23:18:01 +0530 Subject: [PATCH 42/73] Update Swimm in Travis --- .travis.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 887b7cc67..d4c697efa 100644 --- a/.travis.yml +++ b/.travis.yml @@ -98,7 +98,8 @@ script: # verify swimm - cd $TRAVIS_BUILD_DIR -- wget https://firebasestorage.googleapis.com/v0/b/swimmio.appspot.com/o/Release%2Fv018%2Fswimm-0.1.8-linux-executable\?alt\=media\&token\=e59c0a18-577f-4b77-bb3b-91b22c3d8b2a -O swimm +- wget "https://firebasestorage.googleapis.com/v0/b/swimmio.appspot.com/o/Release%2Fv029%2FSwimm_0.2.9_Setup.deb?alt=media&token=774ebd98-cb4e-4615-900c-aada224c1608" -O swimm +- sudo dpkg -i swimm - chmod +x ./swimm - ./swimm --version - ./swimm verify From 96e103ada5027ed64b993cd9df578761bbeac58d Mon Sep 17 00:00:00 2001 From: Shreya Date: Wed, 9 Dec 2020 23:44:38 +0530 Subject: [PATCH 43/73] Add Swimm dependencies to Travis --- .travis.yml | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/.travis.yml b/.travis.yml index d4c697efa..3ae157d6e 100644 --- a/.travis.yml +++ b/.travis.yml @@ -52,6 +52,11 @@ install: # print hugo version (useful for debugging documentation build errors) - hugo version +# dependencies for swimm +- sudo apt-get update +- sudo apt-get -y install libappindicator3-1 +- sudo apt-get -y install libsecret-1-0 + before_script: # Set the server config to `testing`. This is required for for the UTs to pass. - pushd /home/travis/build/guardicore/monkey/monkey From 9783b577613f120eabe7bc33b3510bbca1a67fdb Mon Sep 17 00:00:00 2001 From: Shreya Date: Thu, 10 Dec 2020 00:18:56 +0530 Subject: [PATCH 44/73] Swimm changes in Travis --- .travis.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.travis.yml b/.travis.yml index 3ae157d6e..c1a19254b 100644 --- a/.travis.yml +++ b/.travis.yml @@ -106,8 +106,8 @@ script: - wget "https://firebasestorage.googleapis.com/v0/b/swimmio.appspot.com/o/Release%2Fv029%2FSwimm_0.2.9_Setup.deb?alt=media&token=774ebd98-cb4e-4615-900c-aada224c1608" -O swimm - sudo dpkg -i swimm - chmod +x ./swimm -- ./swimm --version -- ./swimm verify +- swimm --version +- swimm verify after_success: # Upload code coverage results to codecov.io, see https://github.com/codecov/codecov-bash for more information From 77d23ca96946c5610b3a00c779f09506b7203210 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Wed, 9 Dec 2020 15:06:39 -0500 Subject: [PATCH 45/73] deployment_scripts/config: Consolidate exports --- deployment_scripts/config | 37 +++++++++++++------------------------ 1 file changed, 13 insertions(+), 24 deletions(-) diff --git a/deployment_scripts/config b/deployment_scripts/config index f5e4e5d88..cad04a01c 100644 --- a/deployment_scripts/config +++ b/deployment_scripts/config @@ -25,32 +25,21 @@ get_latest_release() { MONKEY_LATEST_RELEASE=$(get_latest_release "guardicore/monkey") # Monkey binaries -LINUX_32_BINARY_NAME="monkey-linux-32" -LINUX_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-linux-32" -export LINUX_32_BINARY_URL -export LINUX_32_BINARY_NAME +export LINUX_32_BINARY_NAME="monkey-linux-32" +export LINUX_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-linux-32" -LINUX_64_BINARY_NAME="monkey-linux-64" -LINUX_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-linux-64" -export LINUX_64_BINARY_URL -export LINUX_64_BINARY_NAME +export LINUX_64_BINARY_NAME="monkey-linux-64" +export LINUX_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-linux-64" -WINDOWS_32_BINARY_NAME="monkey-windows-32.exe" -WINDOWS_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-windows-32.exe" -export WINDOWS_32_BINARY_URL -export WINDOWS_32_BINARY_NAME +export WINDOWS_32_BINARY_NAME="monkey-windows-32.exe" +export WINDOWS_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-windows-32.exe" -WINDOWS_64_BINARY_NAME="monkey-windows-64.exe" -WINDOWS_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-windows-64.exe" -export WINDOWS_64_BINARY_URL -export WINDOWS_64_BINARY_NAME +export WINDOWS_64_BINARY_NAME="monkey-windows-64.exe" +export WINDOWS_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/monkey-windows-64.exe" # Other binaries for monkey -TRACEROUTE_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/traceroute64" -export TRACEROUTE_64_BINARY_URL -TRACEROUTE_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/traceroute32" -export TRACEROUTE_32_BINARY_URL -SAMBACRY_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/sc_monkey_runner64.so" -export SAMBACRY_64_BINARY_URL -SAMBACRY_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/sc_monkey_runner32.so" -export SAMBACRY_32_BINARY_URL +export TRACEROUTE_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/traceroute64" +export TRACEROUTE_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/traceroute32" + +export SAMBACRY_64_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/sc_monkey_runner64.so" +export SAMBACRY_32_BINARY_URL="https://github.com/guardicore/monkey/releases/download/$MONKEY_LATEST_RELEASE/sc_monkey_runner32.so" From 50bec614946974b79c001473abcc7eacd7051589 Mon Sep 17 00:00:00 2001 From: Shreya Date: Thu, 10 Dec 2020 15:22:48 +0530 Subject: [PATCH 46/73] Update apt-get commands for Swimm in Travis --- .travis.yml | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/.travis.yml b/.travis.yml index c1a19254b..504263456 100644 --- a/.travis.yml +++ b/.travis.yml @@ -52,11 +52,6 @@ install: # print hugo version (useful for debugging documentation build errors) - hugo version -# dependencies for swimm -- sudo apt-get update -- sudo apt-get -y install libappindicator3-1 -- sudo apt-get -y install libsecret-1-0 - before_script: # Set the server config to `testing`. This is required for for the UTs to pass. - pushd /home/travis/build/guardicore/monkey/monkey @@ -104,7 +99,7 @@ script: # verify swimm - cd $TRAVIS_BUILD_DIR - wget "https://firebasestorage.googleapis.com/v0/b/swimmio.appspot.com/o/Release%2Fv029%2FSwimm_0.2.9_Setup.deb?alt=media&token=774ebd98-cb4e-4615-900c-aada224c1608" -O swimm -- sudo dpkg -i swimm +- sudo dpkg -i swimm || (sudo apt-get update && sudo apt-get -f install) - chmod +x ./swimm - swimm --version - swimm verify From 866d62239f56b978ad3a7f4e1f180b0f7544d03f Mon Sep 17 00:00:00 2001 From: Shubhendra Singh Chauhan Date: Tue, 15 Dec 2020 17:53:17 +0530 Subject: [PATCH 47/73] Delete .deepsource.toml --- .deepsource.toml | 14 -------------- 1 file changed, 14 deletions(-) delete mode 100644 .deepsource.toml diff --git a/.deepsource.toml b/.deepsource.toml deleted file mode 100644 index 2461cfb80..000000000 --- a/.deepsource.toml +++ /dev/null @@ -1,14 +0,0 @@ -version = 1 - -test_patterns = ["**/**_test.py"] - -[[analyzers]] -name = "python" -enabled = true -dependency_file_paths = [ - "monkey/monkey_island/requirements.txt", - "monkey/infection_monkey/requirements.txt" - ] - - [analyzers.meta] - runtime_version = "3.x.x" From 208f83f4ffc318fd6385b76c1b591e732dc1a065 Mon Sep 17 00:00:00 2001 From: Shreya Date: Tue, 22 Dec 2020 18:49:01 +0530 Subject: [PATCH 48/73] Change label from "other" to "unused" in ZT report documentation --- docs/content/usage/reports/zero-trust.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/content/usage/reports/zero-trust.md b/docs/content/usage/reports/zero-trust.md index 8d6c55aaa..6000584a0 100644 --- a/docs/content/usage/reports/zero-trust.md +++ b/docs/content/usage/reports/zero-trust.md @@ -17,7 +17,7 @@ This diagram provides a quick glance at how your organization scores on each com - {{< label danger Failed >}} At least one of the tests related to this component failed. This means that the Infection Monkey detected an unmet Zero Trust requirement. - {{< label warning Verify >}} At least one of the tests’ results related to this component requires further manual verification. - {{< label success Passed >}} All Tests related to this pillar passed. No violation of a Zero Trust guiding principle was detected. -- {{< label other Unexecuted >}} This status means no tests were executed for this pillar. +- {{< label unused Unexecuted >}} This status means no tests were executed for this pillar. ![Zero Trust Report summary](/images/usage/reports/ztreport1.png "Zero Trust Report summary") From 539a87a5cc03db8c7e526d35ee77b7f60f982801 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 17 Dec 2020 14:51:29 -0500 Subject: [PATCH 49/73] docs: Move "Reports" to the top level of the documentation menu --- docs/content/{usage => }/reports/_index.md | 2 +- docs/content/{usage => }/reports/mitre.md | 0 .../infection_monkey_security_report_example.pdf | Bin docs/content/{usage => }/reports/security.md | 0 docs/content/{usage => }/reports/zero-trust.md | 0 5 files changed, 1 insertion(+), 1 deletion(-) rename docs/content/{usage => }/reports/_index.md (94%) rename docs/content/{usage => }/reports/mitre.md (100%) rename docs/content/{usage => }/reports/security.files/infection_monkey_security_report_example.pdf (100%) rename docs/content/{usage => }/reports/security.md (100%) rename docs/content/{usage => }/reports/zero-trust.md (100%) diff --git a/docs/content/usage/reports/_index.md b/docs/content/reports/_index.md similarity index 94% rename from docs/content/usage/reports/_index.md rename to docs/content/reports/_index.md index 8d1da79b9..d016c6951 100644 --- a/docs/content/usage/reports/_index.md +++ b/docs/content/reports/_index.md @@ -1,7 +1,7 @@ +++ title = "Reports" date = 2020-06-24T21:16:03+03:00 -weight = 5 +weight = 40 chapter = true pre = " " +++ diff --git a/docs/content/usage/reports/mitre.md b/docs/content/reports/mitre.md similarity index 100% rename from docs/content/usage/reports/mitre.md rename to docs/content/reports/mitre.md diff --git a/docs/content/usage/reports/security.files/infection_monkey_security_report_example.pdf b/docs/content/reports/security.files/infection_monkey_security_report_example.pdf similarity index 100% rename from docs/content/usage/reports/security.files/infection_monkey_security_report_example.pdf rename to docs/content/reports/security.files/infection_monkey_security_report_example.pdf diff --git a/docs/content/usage/reports/security.md b/docs/content/reports/security.md similarity index 100% rename from docs/content/usage/reports/security.md rename to docs/content/reports/security.md diff --git a/docs/content/usage/reports/zero-trust.md b/docs/content/reports/zero-trust.md similarity index 100% rename from docs/content/usage/reports/zero-trust.md rename to docs/content/reports/zero-trust.md From ae614c83ed58d07ac793cb27baf49733b8addf5c Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Mon, 4 Jan 2021 15:29:04 -0500 Subject: [PATCH 50/73] docs: Add descriptions for reports and display them on the reports index page --- docs/content/reports/_index.md | 2 +- docs/content/reports/mitre.md | 1 + docs/content/reports/security.md | 1 + docs/content/reports/zero-trust.md | 1 + 4 files changed, 4 insertions(+), 1 deletion(-) diff --git a/docs/content/reports/_index.md b/docs/content/reports/_index.md index d016c6951..40e220e4b 100644 --- a/docs/content/reports/_index.md +++ b/docs/content/reports/_index.md @@ -10,4 +10,4 @@ pre = " " The Monkey offers three reports: -{{% children %}} +{{% children description="true" %}} diff --git a/docs/content/reports/mitre.md b/docs/content/reports/mitre.md index 77cd4ac82..760893534 100644 --- a/docs/content/reports/mitre.md +++ b/docs/content/reports/mitre.md @@ -1,5 +1,6 @@ --- title: "MITRE ATT&CK report" +description: "Maps the Monkey's actions to the MITRE ATT&CK knowledge base" date: 2020-06-24T21:17:18+03:00 draft: false --- diff --git a/docs/content/reports/security.md b/docs/content/reports/security.md index a36106183..e3203d731 100644 --- a/docs/content/reports/security.md +++ b/docs/content/reports/security.md @@ -2,6 +2,7 @@ title: "Security report" date: 2020-06-24T21:16:10+03:00 draft: false +description: "Provides actionable recommendations and insight into an attacker's view of your network" --- {{% notice info %}} diff --git a/docs/content/reports/zero-trust.md b/docs/content/reports/zero-trust.md index 6000584a0..54c9aff31 100644 --- a/docs/content/reports/zero-trust.md +++ b/docs/content/reports/zero-trust.md @@ -2,6 +2,7 @@ title: "Zero Trust report" date: 2020-06-24T21:16:18+03:00 draft: false +description: "Generates a status report with detailed explanations of Zero Trust security gaps and prescriptive instructions on how to rectify them" --- {{% notice info %}} From 708bb88c35aef4fe0ff6e3e49fcdf7cd9e2adc77 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Wed, 6 Jan 2021 11:25:48 -0500 Subject: [PATCH 51/73] docs: Format report list with '"style="p"' --- docs/content/reports/_index.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/content/reports/_index.md b/docs/content/reports/_index.md index 40e220e4b..62996d8a7 100644 --- a/docs/content/reports/_index.md +++ b/docs/content/reports/_index.md @@ -10,4 +10,4 @@ pre = " " The Monkey offers three reports: -{{% children description="true" %}} +{{% children description=true style="p"%}} From 84b422a120e769f39cbd665d7583967db274ba1e Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Fri, 8 Jan 2021 11:42:04 -0500 Subject: [PATCH 52/73] ui: Refactor AdvancedMultiSelect as a class AdvancedMultiSelect can be broken up and composed of smaller, more focused components. This commit refactors AdvancedMultiSelect from a functional component to a class component. --- .../ui-components/AdvancedMultiSelect.js | 162 ++++++++++-------- 1 file changed, 87 insertions(+), 75 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index 9c1468d8d..38e52271e 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -1,5 +1,4 @@ -import React, {useState} from 'react'; - +import React from "react"; import {Card, Button, Form} from 'react-bootstrap'; import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; import {faCheckSquare} from '@fortawesome/free-solid-svg-icons'; @@ -22,14 +21,6 @@ function getSelectValuesAfterClick(valueArray, clickedValue) { } } -function onMasterCheckboxClick(checkboxValue, defaultArray, onChangeFnc) { - if (checkboxValue) { - onChangeFnc([]); - } else { - onChangeFnc(defaultArray); - } -} - // Definitions passed to components only contains value and label, // custom fields like "info" or "links" must be pulled from registry object using this function function getFullDefinitionsFromRegistry(refString, registry) { @@ -46,76 +37,97 @@ function getFullDefinitionByKey(refString, registry, itemKey) { return fullArray.filter(e => (e.enum[0] === itemKey))[0]; } -function setPaneInfo(refString, registry, itemKey, setPaneInfoFnc) { - let definitionObj = getFullDefinitionByKey(refString, registry, itemKey); - setPaneInfoFnc({title: definitionObj.title, content: definitionObj.info, link: definitionObj.link}); -} - function getDefaultPaneParams(refString, registry) { let configSection = getObjectFromRegistryByRef(refString, registry); return ({title: configSection.title, content: configSection.description}); } -function AdvancedMultiSelect(props) { - const [masterCheckbox, setMasterCheckbox] = useState(true); - const { - schema, - id, - options, - value, - required, - disabled, - readonly, - multiple, - autofocus, - onChange, - registry - } = props; - const {enumOptions} = options; - const [infoPaneParams, setInfoPaneParams] = useState(getDefaultPaneParams(schema.items.$ref, registry)); - getDefaultPaneParams(schema.items.$ref, registry); - const selectValue = cloneDeep(value); - return ( -
- - - {props.schema.title} - - - {enumOptions.map(({value, label}, i) => { - return ( - setPaneInfo(schema.items.$ref, registry, value, setInfoPaneParams)}> - - - {label} - - - ); - })} - - -
- ); +class AdvancedMultiSelect extends React.Component { + constructor(props) { + super(props) + this.state = {masterCheckbox: true, infoPaneParams: getDefaultPaneParams(props.schema.items.$ref, props.registry)}; + this.onMasterCheckboxClick = this.onMasterCheckboxClick.bind(this); + } + + onMasterCheckboxClick() { + if (this.state.masterCheckbox) { + this.props.onChange([]); + } else { + this.props.onChange(this.props.schema.default); + } + + this.toggleMasterCheckbox(); + } + + toggleMasterCheckbox() { + this.setState((state) => ({ + masterCheckbox: !state.masterCheckbox + })); + } + + setPaneInfo(refString, registry, itemKey) { + let definitionObj = getFullDefinitionByKey(refString, registry, itemKey); + this.setState({infoPaneParams: {title: definitionObj.title, content: definitionObj.info, link: definitionObj.link}}); + } + render() { + const { + schema, + id, + options, + value, + required, + disabled, + readonly, + multiple, + autofocus, + onChange, + registry + } = this.props; + const {enumOptions} = options; + getDefaultPaneParams(schema.items.$ref, registry); + const selectValue = cloneDeep(value); + return ( +
+ + + {schema.title} + + + { + enumOptions.map(({value, label}, i) => { + return ( + this.setPaneInfo(schema.items.$ref, registry, value)}> + + + + {label} + + + ); + } + )} + + +
+ ); + } } export default AdvancedMultiSelect; From af329d56d826a5092cb3a2535bf0de65bd14600f Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Fri, 8 Jan 2021 16:18:24 -0500 Subject: [PATCH 53/73] ui: Factor MasterCheckbox() out of AdvancedMultiSelect --- .../ui-components/AdvancedMultiSelect.js | 33 ++++++++++++++----- 1 file changed, 25 insertions(+), 8 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index 38e52271e..b875a6426 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -42,6 +42,27 @@ function getDefaultPaneParams(refString, registry) { return ({title: configSection.title, content: configSection.description}); } +function MasterCheckbox(props) { + const { + title, + value, + disabled, + onClick, + checkboxState + } = props; + + return ( + + + {title} + + ); +} + class AdvancedMultiSelect extends React.Component { constructor(props) { super(props) @@ -69,6 +90,7 @@ class AdvancedMultiSelect extends React.Component { let definitionObj = getFullDefinitionByKey(refString, registry, itemKey); this.setState({infoPaneParams: {title: definitionObj.title, content: definitionObj.info, link: definitionObj.link}}); } + render() { const { schema, @@ -88,14 +110,9 @@ class AdvancedMultiSelect extends React.Component { const selectValue = cloneDeep(value); return (
- - - {schema.title} - + Date: Mon, 11 Jan 2021 19:11:27 -0500 Subject: [PATCH 54/73] ui: Factor ChildCheckbox out of AdvancedMultiSelect --- .../ui-components/AdvancedMultiSelect.js | 191 ++++++++++-------- 1 file changed, 107 insertions(+), 84 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index b875a6426..7507f234f 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -10,17 +10,6 @@ import {resolveObjectPath} from './utils/ObjectPathResolver'; import InfoPane from './InfoPane'; -function getSelectValuesAfterClick(valueArray, clickedValue) { - if (valueArray.includes(clickedValue)) { - return valueArray.filter((e) => { - return e !== clickedValue; - }); - } else { - valueArray.push(clickedValue); - return valueArray; - } -} - // Definitions passed to components only contains value and label, // custom fields like "info" or "links" must be pulled from registry object using this function function getFullDefinitionsFromRegistry(refString, registry) { @@ -56,95 +45,129 @@ function MasterCheckbox(props) { {title} ); } +function ChildCheckbox(props) { + const { + onPaneClick, + onClick, + value, + disabled, + label, + checkboxState + } = props; + + return ( + onPaneClick(value)}> + + + {label} + + + ); +} + class AdvancedMultiSelect extends React.Component { - constructor(props) { - super(props) - this.state = {masterCheckbox: true, infoPaneParams: getDefaultPaneParams(props.schema.items.$ref, props.registry)}; - this.onMasterCheckboxClick = this.onMasterCheckboxClick.bind(this); + constructor(props) { + super(props) + this.state = {masterCheckbox: true, infoPaneParams: getDefaultPaneParams(props.schema.items.$ref, props.registry)}; + this.onMasterCheckboxClick = this.onMasterCheckboxClick.bind(this); + this.onChildCheckboxClick = this.onChildCheckboxClick.bind(this); + this.setPaneInfo = this.setPaneInfo.bind(this, props.schema.items.$ref, props.registry); + } + + onMasterCheckboxClick() { + if (this.state.masterCheckbox) { + this.props.onChange([]); + } else { + this.props.onChange(this.props.schema.default); } - onMasterCheckboxClick() { - if (this.state.masterCheckbox) { - this.props.onChange([]); - } else { - this.props.onChange(this.props.schema.default); - } + this.toggleMasterCheckbox(); + } - this.toggleMasterCheckbox(); + onChildCheckboxClick(value) { + this.props.onChange(this.getSelectValuesAfterClick(value)); + } + + getSelectValuesAfterClick(clickedValue) { + const valueArray = cloneDeep(this.props.value); + + if (valueArray.includes(clickedValue)) { + return valueArray.filter((e) => { + return e !== clickedValue; + }); + } else { + valueArray.push(clickedValue); + return valueArray; } + } - toggleMasterCheckbox() { - this.setState((state) => ({ - masterCheckbox: !state.masterCheckbox - })); - } + toggleMasterCheckbox() { + this.setState((state) => ({ + masterCheckbox: !state.masterCheckbox + })); + } - setPaneInfo(refString, registry, itemKey) { - let definitionObj = getFullDefinitionByKey(refString, registry, itemKey); - this.setState({infoPaneParams: {title: definitionObj.title, content: definitionObj.info, link: definitionObj.link}}); - } + setPaneInfo(refString, registry, itemKey) { + let definitionObj = getFullDefinitionByKey(refString, registry, itemKey); + this.setState({infoPaneParams: {title: definitionObj.title, content: definitionObj.info, link: definitionObj.link}}); + } - render() { - const { - schema, - id, - options, - value, - required, - disabled, - readonly, - multiple, - autofocus, - onChange, - registry - } = this.props; - const {enumOptions} = options; - getDefaultPaneParams(schema.items.$ref, registry); - const selectValue = cloneDeep(value); - return ( -
- - - { - enumOptions.map(({value, label}, i) => { - return ( - this.setPaneInfo(schema.items.$ref, registry, value)}> + render() { + const { + schema, + id, + options, + value, + required, + disabled, + readonly, + multiple, + autofocus, + onChange, + registry + } = this.props; - - - {label} - - - ); - } - )} - - -
- ); - } + return ( +
+ + + { + enumOptions.map(({value, label}, i) => { + return ( + + ); + } + )} + + +
+ ); + } } export default AdvancedMultiSelect; From 19bc09196f22e6c1f65e3fd9190c894c4d621a20 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Mon, 11 Jan 2021 20:24:50 -0500 Subject: [PATCH 55/73] ui: Enable mixed-state behavior for master checkbox in AdavncedMultiSelect The AdvancedMultiSelect should adhere to some set of human interface guidelines. In the absence of a formal, agreed upon set of guidelines for Infection Monkey, this commit uses KDE's guidelines for checkboxes: https://hig.kde.org/components/editing/checkbox.html When child checkboxes are not all checked, the master checkbox displays a mixed-state icon, instead of a checked icon. Clicking the mixed-state icon checks all child checkboxes. Clicking an unchecked master checkbox also enables all child checkboxes. In the past, clicking an unchecked master checkbox checked only the *default* child checkboxes. While this may seem desirable so that unsafe exploits do not accidentally get selected by the user, it will confuse and frustrate users, as master/child checkboxes do not normally function this way. If there is concern that users may unknowingly select unsafe exploits/options, we should pop up a warning to inform the user when the config is saved/submitted. Issue #891 --- .../ui-components/AdvancedMultiSelect.js | 60 ++++++++++++++----- 1 file changed, 44 insertions(+), 16 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index 7507f234f..db759b013 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -2,6 +2,7 @@ import React from "react"; import {Card, Button, Form} from 'react-bootstrap'; import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; import {faCheckSquare} from '@fortawesome/free-solid-svg-icons'; +import {faMinusSquare} from '@fortawesome/free-solid-svg-icons'; import {faSquare} from '@fortawesome/free-regular-svg-icons'; import {cloneDeep} from 'lodash'; @@ -9,6 +10,12 @@ import {getComponentHeight} from './utils/HeightCalculator'; import {resolveObjectPath} from './utils/ObjectPathResolver'; import InfoPane from './InfoPane'; +const MasterCheckboxState = { + NONE: 0, + MIXED: 1, + ALL: 2 +} + // Definitions passed to components only contains value and label, // custom fields like "info" or "links" must be pulled from registry object using this function @@ -40,12 +47,19 @@ function MasterCheckbox(props) { checkboxState } = props; + var newCheckboxIcon = faCheckSquare; + + if (checkboxState == MasterCheckboxState.NONE) + newCheckboxIcon = faSquare; + else if (checkboxState == MasterCheckboxState.MIXED) + newCheckboxIcon = faMinusSquare; + return ( {title} @@ -77,42 +91,57 @@ function ChildCheckbox(props) { class AdvancedMultiSelect extends React.Component { constructor(props) { super(props) - this.state = {masterCheckbox: true, infoPaneParams: getDefaultPaneParams(props.schema.items.$ref, props.registry)}; + this.state = { + masterCheckboxState: this.getMasterCheckboxState(props.value), + infoPaneParams: getDefaultPaneParams(props.schema.items.$ref, props.registry) + }; this.onMasterCheckboxClick = this.onMasterCheckboxClick.bind(this); this.onChildCheckboxClick = this.onChildCheckboxClick.bind(this); this.setPaneInfo = this.setPaneInfo.bind(this, props.schema.items.$ref, props.registry); } onMasterCheckboxClick() { - if (this.state.masterCheckbox) { - this.props.onChange([]); - } else { - this.props.onChange(this.props.schema.default); + var newValues = this.props.options.enumOptions.map(({value}) => value); + + if (this.state.masterCheckboxState == MasterCheckboxState.ALL) { + newValues = []; } - this.toggleMasterCheckbox(); + this.props.onChange(newValues); + this.setMasterCheckboxState(newValues); } onChildCheckboxClick(value) { - this.props.onChange(this.getSelectValuesAfterClick(value)); + var selectValues = this.getSelectValuesAfterClick(value) + this.props.onChange(selectValues); + + this.setMasterCheckboxState(selectValues); } getSelectValuesAfterClick(clickedValue) { const valueArray = cloneDeep(this.props.value); if (valueArray.includes(clickedValue)) { - return valueArray.filter((e) => { - return e !== clickedValue; - }); + return valueArray.filter(e => e !== clickedValue); } else { valueArray.push(clickedValue); return valueArray; } } - toggleMasterCheckbox() { - this.setState((state) => ({ - masterCheckbox: !state.masterCheckbox + getMasterCheckboxState(selectValues) { + if (selectValues.length == 0) + return MasterCheckboxState.NONE; + + if (selectValues.length != this.props.options.enumOptions.length) + return MasterCheckboxState.MIXED; + + return MasterCheckboxState.ALL; + } + + setMasterCheckboxState(selectValues) { + this.setState(() => ({ + masterCheckboxState: this.getMasterCheckboxState(selectValues) })); } @@ -132,7 +161,6 @@ class AdvancedMultiSelect extends React.Component { readonly, multiple, autofocus, - onChange, registry } = this.props; @@ -143,7 +171,7 @@ class AdvancedMultiSelect extends React.Component {
+ checkboxState={this.state.masterCheckboxState}/> Date: Tue, 12 Jan 2021 15:14:29 -0500 Subject: [PATCH 56/73] ui: refactor AdvancedMultiSelect.js for readability and flow --- .../ui-components/AdvancedMultiSelect.js | 236 +++++++++--------- 1 file changed, 118 insertions(+), 118 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index db759b013..c418a20c6 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -16,6 +16,10 @@ const MasterCheckboxState = { ALL: 2 } +function getFullDefinitionByKey(refString, registry, itemKey) { + let fullArray = getFullDefinitionsFromRegistry(refString, registry); + return fullArray.filter(e => (e.enum[0] === itemKey))[0]; +} // Definitions passed to components only contains value and label, // custom fields like "info" or "links" must be pulled from registry object using this function @@ -28,16 +32,121 @@ function getObjectFromRegistryByRef(refString, registry) { return resolveObjectPath(refArray, registry); } -function getFullDefinitionByKey(refString, registry, itemKey) { - let fullArray = getFullDefinitionsFromRegistry(refString, registry); - return fullArray.filter(e => (e.enum[0] === itemKey))[0]; -} - function getDefaultPaneParams(refString, registry) { let configSection = getObjectFromRegistryByRef(refString, registry); return ({title: configSection.title, content: configSection.description}); } +class AdvancedMultiSelect extends React.Component { + constructor(props) { + super(props) + + this.state = { + masterCheckboxState: this.getMasterCheckboxState(props.value), + infoPaneParams: getDefaultPaneParams(props.schema.items.$ref, props.registry) + }; + + this.onMasterCheckboxClick = this.onMasterCheckboxClick.bind(this); + this.onChildCheckboxClick = this.onChildCheckboxClick.bind(this); + this.setPaneInfo = this.setPaneInfo.bind(this, props.schema.items.$ref, props.registry); + } + + onMasterCheckboxClick() { + let newValues = this.props.options.enumOptions.map(({value}) => value); + + if (this.state.masterCheckboxState == MasterCheckboxState.ALL) { + newValues = []; + } + + this.props.onChange(newValues); + this.setMasterCheckboxState(newValues); + } + + onChildCheckboxClick(value) { + let selectValues = this.getSelectValuesAfterClick(value) + this.props.onChange(selectValues); + + this.setMasterCheckboxState(selectValues); + } + + getSelectValuesAfterClick(clickedValue) { + const valueArray = cloneDeep(this.props.value); + + if (valueArray.includes(clickedValue)) { + return valueArray.filter(e => e !== clickedValue); + } else { + valueArray.push(clickedValue); + return valueArray; + } + } + + setMasterCheckboxState(selectValues) { + this.setState(() => ({ + masterCheckboxState: this.getMasterCheckboxState(selectValues) + })); + } + + getMasterCheckboxState(selectValues) { + if (selectValues.length == 0) { + return MasterCheckboxState.NONE; + } + + if (selectValues.length != this.props.options.enumOptions.length) { + return MasterCheckboxState.MIXED; + } + + return MasterCheckboxState.ALL; + } + + setPaneInfo(refString, registry, itemKey) { + let definitionObj = getFullDefinitionByKey(refString, registry, itemKey); + this.setState({infoPaneParams: {title: definitionObj.title, content: definitionObj.info, link: definitionObj.link}}); + } + + render() { + const { + schema, + id, + options, + value, + required, + disabled, + readonly, + multiple, + autofocus, + registry + } = this.props; + + const {enumOptions} = options; + getDefaultPaneParams(schema.items.$ref, registry); + + return ( +
+ + + { + enumOptions.map(({value, label}, i) => { + return ( + + ); + } + )} + + +
+ ); + } +} + function MasterCheckbox(props) { const { title, @@ -47,12 +156,13 @@ function MasterCheckbox(props) { checkboxState } = props; - var newCheckboxIcon = faCheckSquare; + let newCheckboxIcon = faCheckSquare; - if (checkboxState == MasterCheckboxState.NONE) + if (checkboxState == MasterCheckboxState.NONE) { newCheckboxIcon = faSquare; - else if (checkboxState == MasterCheckboxState.MIXED) + } else if (checkboxState == MasterCheckboxState.MIXED) { newCheckboxIcon = faMinusSquare; + } return ( @@ -88,114 +198,4 @@ function ChildCheckbox(props) { ); } -class AdvancedMultiSelect extends React.Component { - constructor(props) { - super(props) - this.state = { - masterCheckboxState: this.getMasterCheckboxState(props.value), - infoPaneParams: getDefaultPaneParams(props.schema.items.$ref, props.registry) - }; - this.onMasterCheckboxClick = this.onMasterCheckboxClick.bind(this); - this.onChildCheckboxClick = this.onChildCheckboxClick.bind(this); - this.setPaneInfo = this.setPaneInfo.bind(this, props.schema.items.$ref, props.registry); - } - - onMasterCheckboxClick() { - var newValues = this.props.options.enumOptions.map(({value}) => value); - - if (this.state.masterCheckboxState == MasterCheckboxState.ALL) { - newValues = []; - } - - this.props.onChange(newValues); - this.setMasterCheckboxState(newValues); - } - - onChildCheckboxClick(value) { - var selectValues = this.getSelectValuesAfterClick(value) - this.props.onChange(selectValues); - - this.setMasterCheckboxState(selectValues); - } - - getSelectValuesAfterClick(clickedValue) { - const valueArray = cloneDeep(this.props.value); - - if (valueArray.includes(clickedValue)) { - return valueArray.filter(e => e !== clickedValue); - } else { - valueArray.push(clickedValue); - return valueArray; - } - } - - getMasterCheckboxState(selectValues) { - if (selectValues.length == 0) - return MasterCheckboxState.NONE; - - if (selectValues.length != this.props.options.enumOptions.length) - return MasterCheckboxState.MIXED; - - return MasterCheckboxState.ALL; - } - - setMasterCheckboxState(selectValues) { - this.setState(() => ({ - masterCheckboxState: this.getMasterCheckboxState(selectValues) - })); - } - - setPaneInfo(refString, registry, itemKey) { - let definitionObj = getFullDefinitionByKey(refString, registry, itemKey); - this.setState({infoPaneParams: {title: definitionObj.title, content: definitionObj.info, link: definitionObj.link}}); - } - - render() { - const { - schema, - id, - options, - value, - required, - disabled, - readonly, - multiple, - autofocus, - registry - } = this.props; - - const {enumOptions} = options; - getDefaultPaneParams(schema.items.$ref, registry); - - return ( -
- - - { - enumOptions.map(({value, label}, i) => { - return ( - - ); - } - )} - - -
- ); - } -} - export default AdvancedMultiSelect; From 819e1778c854c36171f25bf862cdcccbc29e4e70 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 12 Jan 2021 15:25:23 -0500 Subject: [PATCH 57/73] docs: Update network-breach.PNG with mixed-state Exploiters checkbox --- .../images/usage/use-cases/network-breach.PNG | Bin 88525 -> 103676 bytes 1 file changed, 0 insertions(+), 0 deletions(-) diff --git a/docs/static/images/usage/use-cases/network-breach.PNG b/docs/static/images/usage/use-cases/network-breach.PNG index 5dfd38ffbbf2471af19e874cd63e75664e4ec8cb..871a36bb67f258057fa58868052b4c0ed443e780 100644 GIT binary patch literal 103676 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 EGgdafG!cup}uY%nyeBy>`!?7-a- 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ν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 U(2hfm9=@WYsG*Q2_t5jd092aGr~m)} literal 88525 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

X&oD8_nmcvY=)p3IQuE((Ol`R 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�s3QksXPqZ{!Lx$(0|8Z*RSR}GYPd#ec6}09;e7dC)B-~$@)nC)DN3CxF-+J<2n89Y3s3FHh}jd)vh(SYZZ`R@L>CAYoD15OPEm|~i$ z{EE|qGbGVCGxuD~<`n6MTtfl?qWW<_jD) z!i_dA&~uxEl3LWC`cGAPo)F|Oz%{xXKpZ`fr*KWPkH}VwDc*JQrOIzr|87ub?^f>3 zss>6a)FQcFljkb^2I_Bbe#5AkgPE5;bHHF4>f$rTf7dQle93u^WI|f)cQP=`%#+(O zySC4-ne+3XC&+k8FHl}UZHkVrik@>I=C*VsBR=|q6aR*7!3z1$U=^>;spCtK4^tYC zxheOcR-`gk*Knxv5c1Oo;$mJdfi-TLOCKB29SR_&uYDUqWW^h+cX8v^)}M(DLgFc9 zj-AY%E`5y#nV#v3@a(~-87Q@jN22vnk$0K%*5)9Z{RXTAU63`Nz7pv*7GXlonrkvC z=3X=>2E&_AvNi)tM=*Lzf*Y`wrk(jyLu zkAO#-{-QF7G_XUO`&*hY{Bxozfzx^v#dQ?Yhkx){FjZ!Q{~#*=(EVk&d<^lo4n8`4 z3vvq=Y>)AUv|MEOeQSLv% zil;Ce&)50cz-boxO6g( zt>C)<$#-0m)RAj;r;mJ>`EtrU^Fk}@yF^>t-&dcfcKwrGdF=F)LaWo?S$J$^zYgSf}Po=tiD{r^$3`sGHJ)prcuG;MN+xArZ`fc(IxZ=ZkTn$6WJ)4LD<7n0XE AYXATM From 94b87f8d9a1a38b6e5440fb48e1b27a5c627af21 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 12 Jan 2021 15:59:16 -0500 Subject: [PATCH 58/73] ui: Remove unnecessary call to getDefaultPaneParams() --- .../cc/ui/src/components/ui-components/AdvancedMultiSelect.js | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index c418a20c6..e303a6bc1 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -113,12 +113,10 @@ class AdvancedMultiSelect extends React.Component { disabled, readonly, multiple, - autofocus, - registry + autofocus } = this.props; const {enumOptions} = options; - getDefaultPaneParams(schema.items.$ref, registry); return (

From 73dd8ddcc97da1156fa09793051ffec6651d8d40 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Wed, 13 Jan 2021 07:35:03 -0500 Subject: [PATCH 59/73] ui: Minor readability and style changes for AdvancedMultiSelect --- .../ui-components/AdvancedMultiSelect.js | 33 ++++++++----------- 1 file changed, 14 insertions(+), 19 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index e303a6bc1..5dca8e86e 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -41,6 +41,8 @@ class AdvancedMultiSelect extends React.Component { constructor(props) { super(props) + this.enumOptions = props.options.enumOptions; + this.state = { masterCheckboxState: this.getMasterCheckboxState(props.value), infoPaneParams: getDefaultPaneParams(props.schema.items.$ref, props.registry) @@ -52,10 +54,10 @@ class AdvancedMultiSelect extends React.Component { } onMasterCheckboxClick() { - let newValues = this.props.options.enumOptions.map(({value}) => value); - - if (this.state.masterCheckboxState == MasterCheckboxState.ALL) { - newValues = []; + if (this.state.masterCheckboxState === MasterCheckboxState.ALL) { + var newValues = []; + } else { + newValues = this.enumOptions.map(({value}) => value); } this.props.onChange(newValues); @@ -87,11 +89,11 @@ class AdvancedMultiSelect extends React.Component { } getMasterCheckboxState(selectValues) { - if (selectValues.length == 0) { + if (selectValues.length === 0) { return MasterCheckboxState.NONE; } - if (selectValues.length != this.props.options.enumOptions.length) { + if (selectValues.length != this.enumOptions.length) { return MasterCheckboxState.MIXED; } @@ -107,8 +109,6 @@ class AdvancedMultiSelect extends React.Component { const { schema, id, - options, - value, required, disabled, readonly, @@ -116,19 +116,17 @@ class AdvancedMultiSelect extends React.Component { autofocus } = this.props; - const {enumOptions} = options; - return (
- { - enumOptions.map(({value, label}, i) => { + this.enumOptions.map(({value, label}, i) => { return ( - {title} From 8d024b900248d94cee76ec79f0dd66befeb7efbf Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 14 Jan 2021 08:37:52 -0500 Subject: [PATCH 60/73] ui: separate MasterCheckbox and ChildCheckbox into their own files --- .../ui-components/AdvancedMultiSelect.js | 65 ++----------------- .../components/ui-components/ChildCheckbox.js | 30 +++++++++ .../ui-components/MasterCheckbox.js | 41 ++++++++++++ 3 files changed, 76 insertions(+), 60 deletions(-) create mode 100644 monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js create mode 100644 monkey/monkey_island/cc/ui/src/components/ui-components/MasterCheckbox.js diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index 5dca8e86e..9d82a1b8d 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -1,20 +1,13 @@ -import React from "react"; -import {Card, Button, Form} from 'react-bootstrap'; -import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; -import {faCheckSquare} from '@fortawesome/free-solid-svg-icons'; -import {faMinusSquare} from '@fortawesome/free-solid-svg-icons'; -import {faSquare} from '@fortawesome/free-regular-svg-icons'; +import React from 'react'; +import {Form} from 'react-bootstrap'; + import {cloneDeep} from 'lodash'; import {getComponentHeight} from './utils/HeightCalculator'; import {resolveObjectPath} from './utils/ObjectPathResolver'; import InfoPane from './InfoPane'; - -const MasterCheckboxState = { - NONE: 0, - MIXED: 1, - ALL: 2 -} +import {MasterCheckbox, MasterCheckboxState} from './MasterCheckbox'; +import ChildCheckbox from './ChildCheckbox'; function getFullDefinitionByKey(refString, registry, itemKey) { let fullArray = getFullDefinitionsFromRegistry(refString, registry); @@ -143,52 +136,4 @@ class AdvancedMultiSelect extends React.Component { } } -function MasterCheckbox(props) { - const { - title, - disabled, - onClick, - checkboxState - } = props; - - let newCheckboxIcon = faCheckSquare; - - if (checkboxState === MasterCheckboxState.NONE) { - newCheckboxIcon = faSquare; - } else if (checkboxState === MasterCheckboxState.MIXED) { - newCheckboxIcon = faMinusSquare; - } - - return ( - - - {title} - - ); -} - -function ChildCheckbox(props) { - const { - onPaneClick, - onClick, - value, - disabled, - label, - checkboxState - } = props; - - return ( - onPaneClick(value)}> - - - {label} - - - ); -} - export default AdvancedMultiSelect; diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js new file mode 100644 index 000000000..353da4b22 --- /dev/null +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js @@ -0,0 +1,30 @@ +import React from 'react'; +import {Button, Form} from 'react-bootstrap'; + +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import {faCheckSquare} from '@fortawesome/free-solid-svg-icons'; +import {faSquare} from '@fortawesome/free-regular-svg-icons'; + +function ChildCheckbox(props) { + const { + onPaneClick, + onClick, + value, + disabled, + label, + checkboxState + } = props; + + return ( + onPaneClick(value)}> + + + {label} + + + ); +} + +export default ChildCheckbox; diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/MasterCheckbox.js b/monkey/monkey_island/cc/ui/src/components/ui-components/MasterCheckbox.js new file mode 100644 index 000000000..0485e64eb --- /dev/null +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/MasterCheckbox.js @@ -0,0 +1,41 @@ +import React from 'react'; +import {Card, Button} from 'react-bootstrap'; + +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import {faCheckSquare} from '@fortawesome/free-solid-svg-icons'; +import {faMinusSquare} from '@fortawesome/free-solid-svg-icons'; +import {faSquare} from '@fortawesome/free-regular-svg-icons'; + +const MasterCheckboxState = { + NONE: 0, + MIXED: 1, + ALL: 2 +} + +function MasterCheckbox(props) { + const { + title, + disabled, + onClick, + checkboxState + } = props; + + let newCheckboxIcon = faCheckSquare; + + if (checkboxState === MasterCheckboxState.NONE) { + newCheckboxIcon = faSquare; + } else if (checkboxState === MasterCheckboxState.MIXED) { + newCheckboxIcon = faMinusSquare; + } + + return ( + + + {title} + + ); +} + +export {MasterCheckboxState, MasterCheckbox}; From 11ea5e1a7eb536628bbd6521ddc8cfc336df7d4d Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 14 Jan 2021 08:44:19 -0500 Subject: [PATCH 61/73] ui: separate json schema-related functions into JsonSchemaHelpers.js --- .../ui-components/AdvancedMultiSelect.js | 23 +----------------- .../ui-components/JsonSchemaHelpers.js | 24 +++++++++++++++++++ 2 files changed, 25 insertions(+), 22 deletions(-) create mode 100644 monkey/monkey_island/cc/ui/src/components/ui-components/JsonSchemaHelpers.js diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index 9d82a1b8d..efd516813 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -4,31 +4,10 @@ import {Form} from 'react-bootstrap'; import {cloneDeep} from 'lodash'; import {getComponentHeight} from './utils/HeightCalculator'; -import {resolveObjectPath} from './utils/ObjectPathResolver'; import InfoPane from './InfoPane'; import {MasterCheckbox, MasterCheckboxState} from './MasterCheckbox'; import ChildCheckbox from './ChildCheckbox'; - -function getFullDefinitionByKey(refString, registry, itemKey) { - let fullArray = getFullDefinitionsFromRegistry(refString, registry); - return fullArray.filter(e => (e.enum[0] === itemKey))[0]; -} - -// Definitions passed to components only contains value and label, -// custom fields like "info" or "links" must be pulled from registry object using this function -function getFullDefinitionsFromRegistry(refString, registry) { - return getObjectFromRegistryByRef(refString, registry).anyOf; -} - -function getObjectFromRegistryByRef(refString, registry) { - let refArray = refString.replace('#', '').split('/'); - return resolveObjectPath(refArray, registry); -} - -function getDefaultPaneParams(refString, registry) { - let configSection = getObjectFromRegistryByRef(refString, registry); - return ({title: configSection.title, content: configSection.description}); -} +import {getFullDefinitionByKey, getDefaultPaneParams} from './JsonSchemaHelpers.js'; class AdvancedMultiSelect extends React.Component { constructor(props) { diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/JsonSchemaHelpers.js b/monkey/monkey_island/cc/ui/src/components/ui-components/JsonSchemaHelpers.js new file mode 100644 index 000000000..06eed4aed --- /dev/null +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/JsonSchemaHelpers.js @@ -0,0 +1,24 @@ +import {resolveObjectPath} from './utils/ObjectPathResolver'; + +function getFullDefinitionByKey(refString, registry, itemKey) { + let fullArray = getFullDefinitionsFromRegistry(refString, registry); + return fullArray.filter(e => (e.enum[0] === itemKey))[0]; +} + +// Definitions passed to components only contains value and label, +// custom fields like "info" or "links" must be pulled from registry object using this function +function getFullDefinitionsFromRegistry(refString, registry) { + return getObjectFromRegistryByRef(refString, registry).anyOf; +} + +function getObjectFromRegistryByRef(refString, registry) { + let refArray = refString.replace('#', '').split('/'); + return resolveObjectPath(refArray, registry); +} + +function getDefaultPaneParams(refString, registry) { + let configSection = getObjectFromRegistryByRef(refString, registry); + return ({title: configSection.title, content: configSection.description}); +} + +export {getFullDefinitionByKey, getDefaultPaneParams}; From bf6db078a6d2e5fddbd49805dbd3f8ade9f6a1ff Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Fri, 15 Jan 2021 08:16:08 -0500 Subject: [PATCH 62/73] ui: add missing semicolons --- .../cc/ui/src/components/ui-components/AdvancedMultiSelect.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index efd516813..56658cf71 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -11,7 +11,7 @@ import {getFullDefinitionByKey, getDefaultPaneParams} from './JsonSchemaHelpers. class AdvancedMultiSelect extends React.Component { constructor(props) { - super(props) + super(props); this.enumOptions = props.options.enumOptions; @@ -37,7 +37,7 @@ class AdvancedMultiSelect extends React.Component { } onChildCheckboxClick(value) { - let selectValues = this.getSelectValuesAfterClick(value) + let selectValues = this.getSelectValuesAfterClick(value); this.props.onChange(selectValues); this.setMasterCheckboxState(selectValues); From e04e11e4ac87967f0a0f2cef0839680001dc87d4 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 21 Jan 2021 15:07:19 -0500 Subject: [PATCH 63/73] ui: add "reset to safe defaults" in AdvancedMultiSelect If the user selects an unsafe exploit or post breach action, a yellow warning button appears that allows the user to reset to safe defaults. --- .../ui-components/AdvancedMultiSelect.js | 60 +++++++++++++++++-- .../ui-components/MasterCheckbox.js | 6 +- .../components/AdvancedMultiSelect.scss | 6 +- 3 files changed, 62 insertions(+), 10 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index 56658cf71..508bafa83 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -1,5 +1,5 @@ import React from 'react'; -import {Form} from 'react-bootstrap'; +import {Button, Card, Form} from 'react-bootstrap'; import {cloneDeep} from 'lodash'; @@ -7,21 +7,45 @@ import {getComponentHeight} from './utils/HeightCalculator'; import InfoPane from './InfoPane'; import {MasterCheckbox, MasterCheckboxState} from './MasterCheckbox'; import ChildCheckbox from './ChildCheckbox'; -import {getFullDefinitionByKey, getDefaultPaneParams} from './JsonSchemaHelpers.js'; +import {getFullDefinitionByKey, getDefaultPaneParams} from './JsonSchemaHelpers'; + +function AdvancedMultiSelectHeader(props) { + const { + title, + disabled, + onCheckboxClick, + checkboxState, + hideReset, + onResetClick + } = props; + + return ( + + + + + ); +} class AdvancedMultiSelect extends React.Component { constructor(props) { super(props); this.enumOptions = props.options.enumOptions; + this.defaultValues = props.schema.default; this.state = { masterCheckboxState: this.getMasterCheckboxState(props.value), + hideReset: this.getHideResetState(props.value), infoPaneParams: getDefaultPaneParams(props.schema.items.$ref, props.registry) }; this.onMasterCheckboxClick = this.onMasterCheckboxClick.bind(this); this.onChildCheckboxClick = this.onChildCheckboxClick.bind(this); + this.onResetClick = this.onResetClick.bind(this); this.setPaneInfo = this.setPaneInfo.bind(this, props.schema.items.$ref, props.registry); } @@ -34,6 +58,7 @@ class AdvancedMultiSelect extends React.Component { this.props.onChange(newValues); this.setMasterCheckboxState(newValues); + this.setHideResetState(newValues); } onChildCheckboxClick(value) { @@ -41,6 +66,7 @@ class AdvancedMultiSelect extends React.Component { this.props.onChange(selectValues); this.setMasterCheckboxState(selectValues); + this.setHideResetState(selectValues); } getSelectValuesAfterClick(clickedValue) { @@ -72,11 +98,34 @@ class AdvancedMultiSelect extends React.Component { return MasterCheckboxState.ALL; } + onResetClick() { + this.props.onChange(this.defaultValues); + this.setHideResetState(this.defaultValues); + this.setMasterCheckboxState(this.defaultValues); + this.setPaneInfoToDefault(); + } + + setHideResetState(selectValues) { + this.setState(() => ({ + hideReset: this.getHideResetState(selectValues) + })); + } + + getHideResetState(selectValues) { + return selectValues.every((value) => this.defaultValues.includes(value)); + } + setPaneInfo(refString, registry, itemKey) { let definitionObj = getFullDefinitionByKey(refString, registry, itemKey); this.setState({infoPaneParams: {title: definitionObj.title, content: definitionObj.info, link: definitionObj.link}}); } + setPaneInfoToDefault() { + this.setState(() => ({ + infoPaneParams: getDefaultPaneParams(this.props.schema.items.$ref, this.props.registry) + })); + } + render() { const { schema, @@ -90,9 +139,10 @@ class AdvancedMultiSelect extends React.Component { return (
- + +
{title} - +
); } diff --git a/monkey/monkey_island/cc/ui/src/styles/components/AdvancedMultiSelect.scss b/monkey/monkey_island/cc/ui/src/styles/components/AdvancedMultiSelect.scss index 3dc1fe9a5..de3d5d542 100644 --- a/monkey/monkey_island/cc/ui/src/styles/components/AdvancedMultiSelect.scss +++ b/monkey/monkey_island/cc/ui/src/styles/components/AdvancedMultiSelect.scss @@ -18,12 +18,14 @@ padding-bottom: 5px; } -.advanced-multi-select .card-header button { - padding-top: 0; +.advanced-multi-select .card-header .master-checkbox span { + padding-bottom: 0.188rem; } .advanced-multi-select .card-header .header-title { font-size: 1.2em; + display: inline-block; + vertical-align: middle; } .advanced-multi-select .choice-block .form-group { From 917d6f574b538899e3ada28bbf8603acff6aa127 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 26 Jan 2021 15:15:11 -0500 Subject: [PATCH 64/73] ui: use class properties syntax in AdvancedMultiSelect --- .../ui-components/AdvancedMultiSelect.js | 19 ++++++++----------- 1 file changed, 8 insertions(+), 11 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index 508bafa83..5c7c11345 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -36,20 +36,17 @@ class AdvancedMultiSelect extends React.Component { this.enumOptions = props.options.enumOptions; this.defaultValues = props.schema.default; + this.infoPaneRefString = props.schema.items.$ref; + this.registry = props.registry; this.state = { masterCheckboxState: this.getMasterCheckboxState(props.value), hideReset: this.getHideResetState(props.value), - infoPaneParams: getDefaultPaneParams(props.schema.items.$ref, props.registry) + infoPaneParams: getDefaultPaneParams(this.infoPaneRefString, this.registry) }; - - this.onMasterCheckboxClick = this.onMasterCheckboxClick.bind(this); - this.onChildCheckboxClick = this.onChildCheckboxClick.bind(this); - this.onResetClick = this.onResetClick.bind(this); - this.setPaneInfo = this.setPaneInfo.bind(this, props.schema.items.$ref, props.registry); } - onMasterCheckboxClick() { + onMasterCheckboxClick = () => { if (this.state.masterCheckboxState === MasterCheckboxState.ALL) { var newValues = []; } else { @@ -61,7 +58,7 @@ class AdvancedMultiSelect extends React.Component { this.setHideResetState(newValues); } - onChildCheckboxClick(value) { + onChildCheckboxClick = (value) => { let selectValues = this.getSelectValuesAfterClick(value); this.props.onChange(selectValues); @@ -98,7 +95,7 @@ class AdvancedMultiSelect extends React.Component { return MasterCheckboxState.ALL; } - onResetClick() { + onResetClick = () => { this.props.onChange(this.defaultValues); this.setHideResetState(this.defaultValues); this.setMasterCheckboxState(this.defaultValues); @@ -115,8 +112,8 @@ class AdvancedMultiSelect extends React.Component { return selectValues.every((value) => this.defaultValues.includes(value)); } - setPaneInfo(refString, registry, itemKey) { - let definitionObj = getFullDefinitionByKey(refString, registry, itemKey); + setPaneInfo = (itemKey) => { + let definitionObj = getFullDefinitionByKey(this.infoPaneRefString, this.registry, itemKey); this.setState({infoPaneParams: {title: definitionObj.title, content: definitionObj.info, link: definitionObj.link}}); } From 145a41ffcf4029c7c26e69ebf7875d4c1f06b9fa Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 26 Jan 2021 15:46:57 -0500 Subject: [PATCH 65/73] ui: move getDefaultPaneParams() to InfoPane.js --- .../src/components/ui-components/AdvancedMultiSelect.js | 4 ++-- .../cc/ui/src/components/ui-components/InfoPane.js | 8 +++++++- .../ui/src/components/ui-components/JsonSchemaHelpers.js | 7 +------ 3 files changed, 10 insertions(+), 9 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index 5c7c11345..bab944093 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -4,10 +4,10 @@ import {Button, Card, Form} from 'react-bootstrap'; import {cloneDeep} from 'lodash'; import {getComponentHeight} from './utils/HeightCalculator'; -import InfoPane from './InfoPane'; +import {getDefaultPaneParams, InfoPane} from './InfoPane'; import {MasterCheckbox, MasterCheckboxState} from './MasterCheckbox'; import ChildCheckbox from './ChildCheckbox'; -import {getFullDefinitionByKey, getDefaultPaneParams} from './JsonSchemaHelpers'; +import {getFullDefinitionByKey} from './JsonSchemaHelpers'; function AdvancedMultiSelectHeader(props) { const { diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/InfoPane.js b/monkey/monkey_island/cc/ui/src/components/ui-components/InfoPane.js index 5c963d87e..6e50ca66d 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/InfoPane.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/InfoPane.js @@ -3,6 +3,12 @@ import React from 'react'; import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; import {faQuestionCircle} from '@fortawesome/free-solid-svg-icons'; +import {getObjectFromRegistryByRef} from './JsonSchemaHelpers'; + +function getDefaultPaneParams(refString, registry) { + let configSection = getObjectFromRegistryByRef(refString, registry); + return ({title: configSection.title, content: configSection.description}); +} function InfoPane(props) { return ( @@ -49,4 +55,4 @@ function getBody(props) { ) } -export default InfoPane +export {getDefaultPaneParams, InfoPane} diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/JsonSchemaHelpers.js b/monkey/monkey_island/cc/ui/src/components/ui-components/JsonSchemaHelpers.js index 06eed4aed..9a3d9c66b 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/JsonSchemaHelpers.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/JsonSchemaHelpers.js @@ -16,9 +16,4 @@ function getObjectFromRegistryByRef(refString, registry) { return resolveObjectPath(refArray, registry); } -function getDefaultPaneParams(refString, registry) { - let configSection = getObjectFromRegistryByRef(refString, registry); - return ({title: configSection.title, content: configSection.description}); -} - -export {getFullDefinitionByKey, getDefaultPaneParams}; +export {getFullDefinitionByKey, getObjectFromRegistryByRef}; From 32cdc034f32fc53c46eed596af426b681cf8b031 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Tue, 26 Jan 2021 15:51:42 -0500 Subject: [PATCH 66/73] ui: fix whitespace in ChildCheckbox.js --- .../components/ui-components/ChildCheckbox.js | 34 +++++++++---------- 1 file changed, 16 insertions(+), 18 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js index 353da4b22..4ce11295e 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js @@ -6,25 +6,23 @@ import {faCheckSquare} from '@fortawesome/free-solid-svg-icons'; import {faSquare} from '@fortawesome/free-regular-svg-icons'; function ChildCheckbox(props) { - const { - onPaneClick, - onClick, - value, - disabled, - label, - checkboxState - } = props; + const { + onPaneClick, + onClick, + value, + disabled, + label, + checkboxState + } = props; - return ( - onPaneClick(value)}> - - - {label} - - - ); + return ( + onPaneClick(value)}> + + {label} + + ); } export default ChildCheckbox; From 155da384c275aa6057ad1b661cacd5c58af51ba9 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 28 Jan 2021 08:14:18 -0500 Subject: [PATCH 67/73] ui: replace "(UNSAFE)" text with warning icon --- .../definitions/exploiter_classes.py | 15 ++++++++++++++- .../config_schema/definitions/finger_classes.py | 8 ++++++++ .../definitions/post_breach_actions.py | 11 +++++++++++ .../definitions/system_info_collector_classes.py | 6 ++++++ .../ui-components/AdvancedMultiSelect.js | 7 ++++++- .../src/components/ui-components/ChildCheckbox.js | 13 ++++++++++--- .../cc/ui/src/styles/pages/ConfigurationPage.scss | 7 +++++++ 7 files changed, 62 insertions(+), 5 deletions(-) diff --git a/monkey/monkey_island/cc/services/config_schema/definitions/exploiter_classes.py b/monkey/monkey_island/cc/services/config_schema/definitions/exploiter_classes.py index 0a5e671a3..25158d73a 100644 --- a/monkey/monkey_island/cc/services/config_schema/definitions/exploiter_classes.py +++ b/monkey/monkey_island/cc/services/config_schema/definitions/exploiter_classes.py @@ -12,6 +12,7 @@ EXPLOITER_CLASSES = { "SmbExploiter" ], "title": "SMB Exploiter", + "safe": True, "attack_techniques": ["T1110", "T1075", "T1035"], "info": "Brute forces using credentials provided by user and" " hashes gathered by mimikatz.", @@ -23,6 +24,7 @@ EXPLOITER_CLASSES = { "WmiExploiter" ], "title": "WMI Exploiter", + "safe": True, "attack_techniques": ["T1110", "T1106"], "info": "Brute forces WMI (Windows Management Instrumentation) " "using credentials provided by user and hashes gathered by mimikatz.", @@ -34,6 +36,7 @@ EXPLOITER_CLASSES = { "MSSQLExploiter" ], "title": "MSSQL Exploiter", + "safe": True, "attack_techniques": ["T1110"], "info": "Tries to brute force into MsSQL server and uses insecure " "configuration to execute commands on server.", @@ -44,7 +47,8 @@ EXPLOITER_CLASSES = { "enum": [ "Ms08_067_Exploiter" ], - "title": "MS08-067 Exploiter (UNSAFE)", + "title": "MS08-067 Exploiter", + "safe": False, "info": "Unsafe exploiter, that might cause system crash due to the use of buffer overflow. " "Uses MS08-067 vulnerability.", "link": "https://www.guardicore.com/infectionmonkey/docs/reference/exploiters/ms08-067/" @@ -55,6 +59,7 @@ EXPLOITER_CLASSES = { "SSHExploiter" ], "title": "SSH Exploiter", + "safe": True, "attack_techniques": ["T1110", "T1145", "T1106"], "info": "Brute forces using credentials provided by user and SSH keys gathered from systems.", "link": "https://www.guardicore.com/infectionmonkey/docs/reference/exploiters/sshexec/" @@ -65,6 +70,7 @@ EXPLOITER_CLASSES = { "ShellShockExploiter" ], "title": "ShellShock Exploiter", + "safe": True, "info": "CVE-2014-6271, based on logic from " "https://github.com/nccgroup/shocker/blob/master/shocker.py .", "link": "https://www.guardicore.com/infectionmonkey/docs/reference/exploiters/shellshock/" @@ -75,6 +81,7 @@ EXPLOITER_CLASSES = { "SambaCryExploiter" ], "title": "SambaCry Exploiter", + "safe": True, "info": "Bruteforces and searches for anonymous shares. Uses Impacket.", "link": "https://www.guardicore.com/infectionmonkey/docs/reference/exploiters/sambacry/" }, @@ -84,6 +91,7 @@ EXPLOITER_CLASSES = { "ElasticGroovyExploiter" ], "title": "ElasticGroovy Exploiter", + "safe": True, "info": "CVE-2015-1427. Logic is based on Metasploit module.", "link": "https://www.guardicore.com/infectionmonkey/docs/reference/exploiters/elasticgroovy/" }, @@ -93,6 +101,7 @@ EXPLOITER_CLASSES = { "Struts2Exploiter" ], "title": "Struts2 Exploiter", + "safe": True, "info": "Exploits struts2 java web framework. CVE-2017-5638. Logic based on " "https://www.exploit-db.com/exploits/41570 .", "link": "https://www.guardicore.com/infectionmonkey/docs/reference/exploiters/struts2/" @@ -103,6 +112,7 @@ EXPLOITER_CLASSES = { "WebLogicExploiter" ], "title": "WebLogic Exploiter", + "safe": True, "info": "Exploits CVE-2017-10271 and CVE-2019-2725 vulnerabilities on WebLogic server.", "link": "https://www.guardicore.com/infectionmonkey/docs/reference/exploiters/weblogic/" }, @@ -112,6 +122,7 @@ EXPLOITER_CLASSES = { "HadoopExploiter" ], "title": "Hadoop/Yarn Exploiter", + "safe": True, "info": "Remote code execution on HADOOP server with YARN and default settings. " "Logic based on https://github.com/vulhub/vulhub/tree/master/hadoop/unauthorized-yarn.", "link": "https://www.guardicore.com/infectionmonkey/docs/reference/exploiters/hadoop/" @@ -122,6 +133,7 @@ EXPLOITER_CLASSES = { "VSFTPDExploiter" ], "title": "VSFTPD Exploiter", + "safe": True, "info": "Exploits a malicious backdoor that was added to the VSFTPD download archive. " "Logic based on Metasploit module.", "link": "https://www.guardicore.com/infectionmonkey/docs/reference/exploiters/vsftpd/" @@ -132,6 +144,7 @@ EXPLOITER_CLASSES = { "DrupalExploiter" ], "title": "Drupal Exploiter", + "safe": True, "info": "Exploits a remote command execution vulnerability in a Drupal server," "for which certain modules (such as RESTful Web Services) are enabled.", "link": "https://www.guardicore.com/infectionmonkey/docs/reference/exploiters/drupal/" diff --git a/monkey/monkey_island/cc/services/config_schema/definitions/finger_classes.py b/monkey/monkey_island/cc/services/config_schema/definitions/finger_classes.py index 405983dc5..5e3f75f33 100644 --- a/monkey/monkey_island/cc/services/config_schema/definitions/finger_classes.py +++ b/monkey/monkey_island/cc/services/config_schema/definitions/finger_classes.py @@ -10,6 +10,7 @@ FINGER_CLASSES = { "SMBFinger" ], "title": "SMBFinger", + "safe": True, "info": "Figures out if SMB is running and what's the version of it.", "attack_techniques": ["T1210"] }, @@ -19,6 +20,7 @@ FINGER_CLASSES = { "SSHFinger" ], "title": "SSHFinger", + "safe": True, "info": "Figures out if SSH is running.", "attack_techniques": ["T1210"] }, @@ -28,6 +30,7 @@ FINGER_CLASSES = { "PingScanner" ], "title": "PingScanner", + "safe": True, "info": "Tries to identify if host is alive and which OS it's running by ping scan." }, { @@ -36,6 +39,7 @@ FINGER_CLASSES = { "HTTPFinger" ], "title": "HTTPFinger", + "safe": True, "info": "Checks if host has HTTP/HTTPS ports open." }, { @@ -44,6 +48,7 @@ FINGER_CLASSES = { "MySQLFinger" ], "title": "MySQLFinger", + "safe": True, "info": "Checks if MySQL server is running and tries to get it's version.", "attack_techniques": ["T1210"] }, @@ -53,6 +58,7 @@ FINGER_CLASSES = { "MSSQLFinger" ], "title": "MSSQLFinger", + "safe": True, "info": "Checks if Microsoft SQL service is running and tries to gather information about it.", "attack_techniques": ["T1210"] }, @@ -62,6 +68,7 @@ FINGER_CLASSES = { "ElasticFinger" ], "title": "ElasticFinger", + "safe": True, "info": "Checks if ElasticSearch is running and attempts to find it's version.", "attack_techniques": ["T1210"] }, @@ -71,6 +78,7 @@ FINGER_CLASSES = { "WindowsServerFinger" ], "title": "WindowsServerFinger", + "safe": True, "info": "Checks if server is a Windows Server and tests if it is vulnerable to Zerologon.", "attack_techniques": ["T1210"] } diff --git a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py index f1fe0f6f2..16dc0735e 100644 --- a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py +++ b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py @@ -10,6 +10,7 @@ POST_BREACH_ACTIONS = { "BackdoorUser" ], "title": "Back door user", + "safe": True, "info": "Attempts to create a new user on the system and delete it afterwards.", "attack_techniques": ["T1136"] }, @@ -19,6 +20,7 @@ POST_BREACH_ACTIONS = { "CommunicateAsNewUser" ], "title": "Communicate as new user", + "safe": True, "info": "Attempts to create a new user, create HTTPS requests as that user and delete the user " "afterwards.", "attack_techniques": ["T1136"] @@ -29,6 +31,7 @@ POST_BREACH_ACTIONS = { "ModifyShellStartupFiles" ], "title": "Modify shell startup files", + "safe": True, "info": "Attempts to modify shell startup files, like ~/.profile, ~/.bashrc, ~/.bash_profile " "in linux, and profile.ps1 in windows. Reverts modifications done afterwards.", "attack_techniques": ["T1156", "T1504"] @@ -39,6 +42,7 @@ POST_BREACH_ACTIONS = { "HiddenFiles" ], "title": "Hidden files and directories", + "safe": True, "info": "Attempts to create a hidden file and remove it afterward.", "attack_techniques": ["T1158"] }, @@ -48,6 +52,7 @@ POST_BREACH_ACTIONS = { "TrapCommand" ], "title": "Trap", + "safe": True, "info": "On Linux systems, attempts to trap an interrupt signal in order to execute a command " "upon receiving that signal. Removes the trap afterwards.", "attack_techniques": ["T1154"] @@ -58,6 +63,7 @@ POST_BREACH_ACTIONS = { "ChangeSetuidSetgid" ], "title": "Setuid and Setgid", + "safe": True, "info": "On Linux systems, attempts to set the setuid and setgid bits of a new file. " "Removes the file afterwards.", "attack_techniques": ["T1166"] @@ -68,6 +74,7 @@ POST_BREACH_ACTIONS = { "ScheduleJobs" ], "title": "Job scheduling", + "safe": True, "info": "Attempts to create a scheduled job on the system and remove it.", "attack_techniques": ["T1168", "T1053"] }, @@ -77,6 +84,7 @@ POST_BREACH_ACTIONS = { "Timestomping" ], "title": "Timestomping", + "safe": True, "info": "Creates a temporary file and attempts to modify its time attributes. Removes the file afterwards.", "attack_techniques": ["T1099"] }, @@ -86,6 +94,7 @@ POST_BREACH_ACTIONS = { "SignedScriptProxyExecution" ], "title": "Signed script proxy execution", + "safe": False, "info": "On Windows systems, attemps to execute an arbitrary file " "with the help of a pre-existing signed script.", "attack_techniques": ["T1216"] @@ -96,6 +105,7 @@ POST_BREACH_ACTIONS = { "AccountDiscovery" ], "title": "Account Discovery", + "safe": True, "info": "Attempts to get a listing of user accounts on the system.", "attack_techniques": ["T1087"] }, @@ -105,6 +115,7 @@ POST_BREACH_ACTIONS = { "ClearCommandHistory" ], "title": "Clear command history", + "safe": False, "info": "Attempts to clear the command history.", "attack_techniques": ["T1146"] } diff --git a/monkey/monkey_island/cc/services/config_schema/definitions/system_info_collector_classes.py b/monkey/monkey_island/cc/services/config_schema/definitions/system_info_collector_classes.py index 5f113f4a7..174133f43 100644 --- a/monkey/monkey_island/cc/services/config_schema/definitions/system_info_collector_classes.py +++ b/monkey/monkey_island/cc/services/config_schema/definitions/system_info_collector_classes.py @@ -16,6 +16,7 @@ SYSTEM_INFO_COLLECTOR_CLASSES = { ENVIRONMENT_COLLECTOR ], "title": "Environment collector", + "safe": True, "info": "Collects information about machine's environment (on premise/GCP/AWS).", "attack_techniques": ["T1082"] }, @@ -25,6 +26,7 @@ SYSTEM_INFO_COLLECTOR_CLASSES = { MIMIKATZ_COLLECTOR ], "title": "Mimikatz collector", + "safe": True, "info": "Collects credentials from Windows credential manager.", "attack_techniques": ["T1003", "T1005"] }, @@ -34,6 +36,7 @@ SYSTEM_INFO_COLLECTOR_CLASSES = { AWS_COLLECTOR ], "title": "AWS collector", + "safe": True, "info": "If on AWS, collects more information about the AWS instance currently running on.", "attack_techniques": ["T1082"] }, @@ -43,6 +46,7 @@ SYSTEM_INFO_COLLECTOR_CLASSES = { HOSTNAME_COLLECTOR ], "title": "Hostname collector", + "safe": True, "info": "Collects machine's hostname.", "attack_techniques": ["T1082", "T1016"] }, @@ -52,6 +56,7 @@ SYSTEM_INFO_COLLECTOR_CLASSES = { PROCESS_LIST_COLLECTOR ], "title": "Process list collector", + "safe": True, "info": "Collects a list of running processes on the machine.", "attack_techniques": ["T1082"] }, @@ -61,6 +66,7 @@ SYSTEM_INFO_COLLECTOR_CLASSES = { AZURE_CRED_COLLECTOR ], "title": "Azure credential collector", + "safe": True, "info": "Collects password credentials from Azure VMs", "attack_techniques": ["T1003", "T1005"] } diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index bab944093..b92ff3f1a 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -123,6 +123,10 @@ class AdvancedMultiSelect extends React.Component { })); } + isSafe(itemKey) { + return getFullDefinitionByKey(this.infoPaneRefString, this.registry, itemKey).safe; + } + render() { const { schema, @@ -149,7 +153,8 @@ class AdvancedMultiSelect extends React.Component { return ( + disabled={disabled} label={label} checkboxState={this.props.value.includes(value)} + safe={this.isSafe(value)}/> ); } )} diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js index 4ce11295e..1cd3caa8c 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js @@ -2,7 +2,7 @@ import React from 'react'; import {Button, Form} from 'react-bootstrap'; import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; -import {faCheckSquare} from '@fortawesome/free-solid-svg-icons'; +import {faCheckSquare, faExclamationTriangle} from '@fortawesome/free-solid-svg-icons'; import {faSquare} from '@fortawesome/free-regular-svg-icons'; function ChildCheckbox(props) { @@ -12,15 +12,22 @@ function ChildCheckbox(props) { value, disabled, label, - checkboxState + checkboxState, + safe } = props; + let displayLabel = [{label}]; + + if (!safe) { + displayLabel.push() + } + return ( onPaneClick(value)}> - {label} + {displayLabel} ); } diff --git a/monkey/monkey_island/cc/ui/src/styles/pages/ConfigurationPage.scss b/monkey/monkey_island/cc/ui/src/styles/pages/ConfigurationPage.scss index e5c6c08bc..435047845 100644 --- a/monkey/monkey_island/cc/ui/src/styles/pages/ConfigurationPage.scss +++ b/monkey/monkey_island/cc/ui/src/styles/pages/ConfigurationPage.scss @@ -57,3 +57,10 @@ white-space: pre-wrap; } +.unsafe-indicator { + text-transform: uppercase; + color: #ffc107; + font-weight: 900; + margin-left: .75em; + margin-right: .75em; +} From 5942fad434b0136aeffc693033c05228977b6a45 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 28 Jan 2021 08:51:30 -0500 Subject: [PATCH 68/73] ui: extract ChildCheckboxContainer component out of AdvancedMultiSelect --- .../ui-components/AdvancedMultiSelect.js | 28 +++++--------- .../components/ui-components/ChildCheckbox.js | 37 ++++++++++++++++++- 2 files changed, 45 insertions(+), 20 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index b92ff3f1a..90d8cf818 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -1,12 +1,11 @@ import React from 'react'; -import {Button, Card, Form} from 'react-bootstrap'; +import {Button, Card} from 'react-bootstrap'; import {cloneDeep} from 'lodash'; -import {getComponentHeight} from './utils/HeightCalculator'; import {getDefaultPaneParams, InfoPane} from './InfoPane'; import {MasterCheckbox, MasterCheckboxState} from './MasterCheckbox'; -import ChildCheckbox from './ChildCheckbox'; +import ChildCheckboxContainer from './ChildCheckbox'; import {getFullDefinitionByKey} from './JsonSchemaHelpers'; function AdvancedMultiSelectHeader(props) { @@ -123,7 +122,7 @@ class AdvancedMultiSelect extends React.Component { })); } - isSafe(itemKey) { + isSafe = (itemKey) => { return getFullDefinitionByKey(this.infoPaneRefString, this.registry, itemKey).safe; } @@ -144,21 +143,12 @@ class AdvancedMultiSelect extends React.Component { disabled={disabled} onCheckboxClick={this.onMasterCheckboxClick} checkboxState={this.state.masterCheckboxState} hideReset={this.state.hideReset} onResetClick={this.onResetClick}/> - - { - this.enumOptions.map(({value, label}, i) => { - return ( - - ); - } - )} - + + + diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js index 1cd3caa8c..e740734d5 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js @@ -5,6 +5,41 @@ import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; import {faCheckSquare, faExclamationTriangle} from '@fortawesome/free-solid-svg-icons'; import {faSquare} from '@fortawesome/free-regular-svg-icons'; +import {getComponentHeight} from './utils/HeightCalculator'; + +function ChildCheckboxContainer(props) { + const { + enumOptions, + id, + multiple, + required, + disabled, + autofocus, + onPaneClick, + onCheckboxClick, + selectedValues, + isSafe + } = props; + + return( + + { + enumOptions.map(({value, label}, i) => { + return ( + + ); + } + )} + + ); +} + function ChildCheckbox(props) { const { onPaneClick, @@ -32,4 +67,4 @@ function ChildCheckbox(props) { ); } -export default ChildCheckbox; +export default ChildCheckboxContainer; From 5f9470d17c408e3a8087efb6716d9c68b59f985b Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 28 Jan 2021 09:00:55 -0500 Subject: [PATCH 69/73] ui: extract WarningIcon component from ChildCheckbox.js --- .../ui/src/components/ui-components/ChildCheckbox.js | 5 +++-- .../cc/ui/src/components/ui-components/WarningIcon.js | 11 +++++++++++ 2 files changed, 14 insertions(+), 2 deletions(-) create mode 100644 monkey/monkey_island/cc/ui/src/components/ui-components/WarningIcon.js diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js index e740734d5..57088f0c2 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js @@ -2,10 +2,11 @@ import React from 'react'; import {Button, Form} from 'react-bootstrap'; import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; -import {faCheckSquare, faExclamationTriangle} from '@fortawesome/free-solid-svg-icons'; +import {faCheckSquare} from '@fortawesome/free-solid-svg-icons'; import {faSquare} from '@fortawesome/free-regular-svg-icons'; import {getComponentHeight} from './utils/HeightCalculator'; +import WarningIcon from './WarningIcon'; function ChildCheckboxContainer(props) { const { @@ -54,7 +55,7 @@ function ChildCheckbox(props) { let displayLabel = [{label}]; if (!safe) { - displayLabel.push() + displayLabel.push() } return ( diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/WarningIcon.js b/monkey/monkey_island/cc/ui/src/components/ui-components/WarningIcon.js new file mode 100644 index 000000000..2e759ccb6 --- /dev/null +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/WarningIcon.js @@ -0,0 +1,11 @@ +import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; +import {faExclamationTriangle} from '@fortawesome/free-solid-svg-icons'; +import React from 'react'; + +function WarningIcon() { + return ( + + ); +} + +export default WarningIcon; From 5ed102bd0957c96b2ea5f505c44292f4be2896e6 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 28 Jan 2021 10:08:31 -0500 Subject: [PATCH 70/73] config_schema: fix typo in Signed script proxy execution PBA --- .../services/config_schema/definitions/post_breach_actions.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py index 16dc0735e..857e80da4 100644 --- a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py +++ b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py @@ -95,7 +95,7 @@ POST_BREACH_ACTIONS = { ], "title": "Signed script proxy execution", "safe": False, - "info": "On Windows systems, attemps to execute an arbitrary file " + "info": "On Windows systems, attempts to execute an arbitrary file " "with the help of a pre-existing signed script.", "attack_techniques": ["T1216"] }, From 7ec8f0394c6e64883e5e54c3d6fdb29272e9b28c Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 28 Jan 2021 10:12:28 -0500 Subject: [PATCH 71/73] ui: add warning message to PBA/Exploiters InfoPane --- .../ui-components/AdvancedMultiSelect.js | 14 ++++++++-- .../src/components/ui-components/InfoPane.js | 26 +++++++++++++++++-- .../cc/ui/src/styles/components/InfoPane.scss | 7 +++++ 3 files changed, 43 insertions(+), 4 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js index 90d8cf818..955aec509 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/AdvancedMultiSelect.js @@ -113,7 +113,16 @@ class AdvancedMultiSelect extends React.Component { setPaneInfo = (itemKey) => { let definitionObj = getFullDefinitionByKey(this.infoPaneRefString, this.registry, itemKey); - this.setState({infoPaneParams: {title: definitionObj.title, content: definitionObj.info, link: definitionObj.link}}); + this.setState( + { + infoPaneParams: { + title: definitionObj.title, + content: definitionObj.info, + link: definitionObj.link, + showWarning: !(this.isSafe(itemKey)) + } + } + ); } setPaneInfoToDefault() { @@ -151,7 +160,8 @@ class AdvancedMultiSelect extends React.Component { + link={this.state.infoPaneParams.link} + showWarning={this.state.infoPaneParams.showWarning}/>
); } diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/InfoPane.js b/monkey/monkey_island/cc/ui/src/components/ui-components/InfoPane.js index 6e50ca66d..f0545a5c6 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/InfoPane.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/InfoPane.js @@ -4,10 +4,16 @@ import {FontAwesomeIcon} from '@fortawesome/react-fontawesome'; import {faQuestionCircle} from '@fortawesome/free-solid-svg-icons'; import {getObjectFromRegistryByRef} from './JsonSchemaHelpers'; +import WarningIcon from './WarningIcon'; function getDefaultPaneParams(refString, registry) { let configSection = getObjectFromRegistryByRef(refString, registry); - return ({title: configSection.title, content: configSection.description}); + return ( + { + title: configSection.title, + content: configSection.description, + showWarning: false + }); } function InfoPane(props) { @@ -48,11 +54,27 @@ function getSubtitle(props) { } function getBody(props) { + let body = [{props.body}]; + + if (props.showWarning) { + body.push(getWarning()); + } + return ( - {props.body} + {body} ) } +function getWarning() { + return ( +
+ This option may cause a system to become unstable or + change the system's state in undesirable ways. Therefore, this option + is not recommended for use in production or other sensitive environments. +
+ ); +} + export {getDefaultPaneParams, InfoPane} diff --git a/monkey/monkey_island/cc/ui/src/styles/components/InfoPane.scss b/monkey/monkey_island/cc/ui/src/styles/components/InfoPane.scss index 8c61d873f..a177ed7e1 100644 --- a/monkey/monkey_island/cc/ui/src/styles/components/InfoPane.scss +++ b/monkey/monkey_island/cc/ui/src/styles/components/InfoPane.scss @@ -27,3 +27,10 @@ margin: 10px 15px; padding: 0; } + +.info-pane-warning { + margin-top: 1em; +} +.info-pane-warning .unsafe-indicator { + margin-left: 0em; +} From 9d9e8168fb2c23367b9947273aa1a041687b3e2e Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 28 Jan 2021 10:18:40 -0500 Subject: [PATCH 72/73] ui: rename unsafe-indicator to warning-icon --- .../cc/ui/src/components/ui-components/ChildCheckbox.js | 2 +- .../cc/ui/src/components/ui-components/WarningIcon.js | 2 +- monkey/monkey_island/cc/ui/src/styles/components/InfoPane.scss | 2 +- .../monkey_island/cc/ui/src/styles/pages/ConfigurationPage.scss | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js index 57088f0c2..47a86dab6 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/ChildCheckbox.js @@ -55,7 +55,7 @@ function ChildCheckbox(props) { let displayLabel = [{label}]; if (!safe) { - displayLabel.push() + displayLabel.push() } return ( diff --git a/monkey/monkey_island/cc/ui/src/components/ui-components/WarningIcon.js b/monkey/monkey_island/cc/ui/src/components/ui-components/WarningIcon.js index 2e759ccb6..e06f00ec9 100644 --- a/monkey/monkey_island/cc/ui/src/components/ui-components/WarningIcon.js +++ b/monkey/monkey_island/cc/ui/src/components/ui-components/WarningIcon.js @@ -4,7 +4,7 @@ import React from 'react'; function WarningIcon() { return ( - + ); } diff --git a/monkey/monkey_island/cc/ui/src/styles/components/InfoPane.scss b/monkey/monkey_island/cc/ui/src/styles/components/InfoPane.scss index a177ed7e1..561e436cf 100644 --- a/monkey/monkey_island/cc/ui/src/styles/components/InfoPane.scss +++ b/monkey/monkey_island/cc/ui/src/styles/components/InfoPane.scss @@ -31,6 +31,6 @@ .info-pane-warning { margin-top: 1em; } -.info-pane-warning .unsafe-indicator { +.info-pane-warning .warning-icon { margin-left: 0em; } diff --git a/monkey/monkey_island/cc/ui/src/styles/pages/ConfigurationPage.scss b/monkey/monkey_island/cc/ui/src/styles/pages/ConfigurationPage.scss index 435047845..98e598c81 100644 --- a/monkey/monkey_island/cc/ui/src/styles/pages/ConfigurationPage.scss +++ b/monkey/monkey_island/cc/ui/src/styles/pages/ConfigurationPage.scss @@ -57,7 +57,7 @@ white-space: pre-wrap; } -.unsafe-indicator { +.warning-icon { text-transform: uppercase; color: #ffc107; font-weight: 900; From ce9a398f28a0e22122035f6be5bc8ab5ee6ef79a Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 28 Jan 2021 10:58:42 -0500 Subject: [PATCH 73/73] swimm: autosync PBA tutorial --- .swm/JFXftJml8DpmuCPBA9rL.swm | 57 ++++++++---- .swm/tbxb2cGgUiJQ8Btma0fp.swm | 169 +++++++++++++++++++++++----------- 2 files changed, 156 insertions(+), 70 deletions(-) diff --git a/.swm/JFXftJml8DpmuCPBA9rL.swm b/.swm/JFXftJml8DpmuCPBA9rL.swm index 7c186126e..3e348a3a6 100644 --- a/.swm/JFXftJml8DpmuCPBA9rL.swm +++ b/.swm/JFXftJml8DpmuCPBA9rL.swm @@ -1,30 +1,51 @@ { "id": "JFXftJml8DpmuCPBA9rL", "name": "Add details about your new PBA", - "dod": "WW91JTIwc2hvdWxkJTIwYWRkJTIweW91ciUyMG5ldyUyMFBCQSdzJTIwZGV0YWlscyUyMHRvJTIwdGhlJTIwY29uZmlndXJhdGlvbi4=", - "description": "SW4lMjBvcmRlciUyMHRvJTIwbWFrZSUyMHN1cmUlMjB0aGF0JTIwdGhlJTIwbmV3JTIwJTYwU2NoZWR1bGVKb2JzJTYwJTIwUEJBJTIwaXMlMjBzaG93biUyMGluJTIwdGhlJTIwY29uZmlndXJhdGlvbiUyMG9uJTIwdGhlJTIwTW9ua2V5JTIwSXNsYW5kJTJDJTIweW91JTIwbmVlZCUyMHRvJTIwYWRkJTIwaXRzJTIwZGV0YWlscyUyMHRvJTIwdGhlJTIwY29uZmlndXJhdGlvbiUyMGZpbGUocykuJTIwJTNDYnIlM0UlM0NiciUzRSUwQSUwQVNpbmNlJTIwdGhpcyUyMHBhcnRpY3VsYXIlMjBQQkElMjBpcyUyMHJlbGF0ZWQlMjB0byUyMHRoZSUyME1JVFJFJTIwdGVjaG5pcXVlcyUyMCU1QlQxMTY4JTVEKGh0dHBzJTNBJTJGJTJGYXR0YWNrLm1pdHJlLm9yZyUyRnRlY2huaXF1ZXMlMkZUMTE2OCklMjBhbmQlMjAlNUJUMTA1MyU1RChodHRwcyUzQSUyRiUyRmF0dGFjay5taXRyZS5vcmclMkZ0ZWNobmlxdWVzJTJGVDEwNTMpJTJDJTIwbWFrZSUyMHN1cmUlMjB0byUyMGxpbmslMjB0aGUlMjBQQkElMjB3aXRoJTIwdGhlc2UlMjB0ZWNobmlxdWVzJTIwaW4lMjB0aGUlMjBjb25maWd1cmF0aW9uJTIwYXMlMjB3ZWxsLiUyMCUzQ2JyJTNFJTNDYnIlM0UlMEElMEFFYWNoJTIwcGFydCUyMG9mJTIwdGhlJTIwY29uZmlndXJhdGlvbiUyMGhhcyUyMGFuJTIwaW1wb3J0YW50JTIwcm9sZSUyMCUyMCUwQS0lMjAqZW51bSolMjAlRTIlODAlOTQlMjBjb250YWlucyUyMHRoZSUyMHJlbGV2YW50JTIwUEJBJ3MlMjBjbGFzcyUyMG5hbWUocyklMEEtJTIwKnRpdGxlKiUyMCVFMiU4MCU5NCUyMGhvbGRzJTIwdGhlJTIwbmFtZSUyMG9mJTIwdGhlJTIwUEJBJTIwd2hpY2glMjBpcyUyMGRpc3BsYXllZCUyMGluJTIwdGhlJTIwY29uZmlndXJhdGlvbiUyMG9uJTIwdGhlJTIwTW9ua2V5JTIwSXNsYW5kJTBBLSUyMCppbmZvKiUyMCVFMiU4MCU5NCUyMGNvbnNpc3RzJTIwb2YlMjBhbiUyMGVsYWJvcmF0aW9uJTIwb24lMjB0aGUlMjBQQkEncyUyMHdvcmtpbmclMjB3aGljaCUyMGlzJTIwZGlzcGxheWVkJTIwaW4lMjB0aGUlMjBjb25maWd1cmF0aW9uJTIwb24lMjB0aGUlMjBNb25rZXklMjBJc2xhbmQlMEEtJTIwKmF0dGFja190ZWNobmlxdWVzKiUyMCVFMiU4MCU5NCUyMGhhcyUyMHRoZSUyMElEcyUyMG9mJTIwdGhlJTIwTUlUUkUlMjB0ZWNobmlxdWVzJTIwYXNzb2NpYXRlZCUyMHdpdGglMjB0aGUlMjBQQkElMEElMEElMjMlMjMlMjBNYW51YWwlMjB0ZXN0JTIwJTIwJTBBT25jZSUyMHlvdSUyMHRoaW5rJTIweW91J3JlJTIwZG9uZS4uLiUwQS0lMjBSdW4lMjB0aGUlMjBNb25rZXklMjBJc2xhbmQlMEEtJTIwWW91JTIwc2hvdWxkJTIwYmUlMjBhYmxlJTIwdG8lMjBzZWUlMjB5b3VyJTIwbmV3JTIwUEJBJTIwdW5kZXIlMjB0aGUlMjAlMjJNb25rZXklMjIlMjB0YWIlMjBpbiUyMHRoZSUyMGNvbmZpZ3VyYXRpb24lMkMlMjBhbG9uZyUyMHdpdGglMjBpdHMlMjBpbmZvcm1hdGlvbiUyMHdoZW4lMjB5b3UlMjBjbGljayUyMG9uJTIwaXQlMEEtJTIwRnVydGhlciUyQyUyMHdoZW4lMjB5b3UlMjBlbmFibGUlMkZkaXNhYmxlJTIwdGhlJTIwYXNzb2NpYXRlZCUyME1JVFJFJTIwdGVjaG5pcXVlcyUyMHVuZGVyJTIwdGhlJTIwQVRUJTI2Q0slMjB0YWIlMjBpbiUyMHRoZSUyMGNvbmZpZ3VyYXRpb24lMkMlMjB0aGUlMjBQQkElMjBzaG91bGQlMjBhbHNvJTIwYmUlMjBlbmFibGVkJTJGZGlzYWJsZWQlMEElMEElM0NpbWclMjBzcmMlM0QlMjJodHRwcyUzQSUyRiUyRmkuaW1ndXIuY29tJTJGYTVWU2tMNS5naWYlMjIlMjBoZWlnaHQlM0Q0MDAlM0U=", - "summary": "LSUyMFRoZSUyMFBCQSUyMGRldGFpbHMlMjBpbiUyMHRoaXMlMjBmaWxlJTIwYXJlJTIwcmVmbGVjdGVkJTIwb24lMjB0aGUlMjBNb25rZXklMjBJc2xhbmQlMjBpbiUyMHRoZSUyMFBCQSUyMGNvbmZpZ3VyYXRpb24uJTBBLSUyMFBCQXMlMjBhcmUlMjBhbHNvJTIwbGlua2VkJTIwdG8lMjB0aGUlMjByZWxldmFudCUyME1JVFJFJTIwdGVjaG5pcXVlcyUyMGluJTIwdGhpcyUyMGZpbGUlMkMlMjB3aG9zZSUyMHJlc3VsdHMlMjBjYW4lMjB0aGVuJTIwYmUlMjBzZWVuJTIwaW4lMjB0aGUlMjBNSVRSRSUyMEFUVCUyNkNLJTIwcmVwb3J0JTIwb24lMjB0aGUlMjBNb25rZXklMjBJc2xhbmQu", - "diff": "ZGlmZiUyMC0tZ2l0JTIwYSUyRm1vbmtleSUyRm1vbmtleV9pc2xhbmQlMkZjYyUyRnNlcnZpY2VzJTJGY29uZmlnX3NjaGVtYSUyRmRlZmluaXRpb25zJTJGcG9zdF9icmVhY2hfYWN0aW9ucy5weSUyMGIlMkZtb25rZXklMkZtb25rZXlfaXNsYW5kJTJGY2MlMkZzZXJ2aWNlcyUyRmNvbmZpZ19zY2hlbWElMkZkZWZpbml0aW9ucyUyRnBvc3RfYnJlYWNoX2FjdGlvbnMucHklMEFpbmRleCUyMGYxZmUwZjZmLi5jY2UzN2IyNCUyMDEwMDY0NCUwQS0tLSUyMGElMkZtb25rZXklMkZtb25rZXlfaXNsYW5kJTJGY2MlMkZzZXJ2aWNlcyUyRmNvbmZpZ19zY2hlbWElMkZkZWZpbml0aW9ucyUyRnBvc3RfYnJlYWNoX2FjdGlvbnMucHklMEElMkIlMkIlMkIlMjBiJTJGbW9ua2V5JTJGbW9ua2V5X2lzbGFuZCUyRmNjJTJGc2VydmljZXMlMkZjb25maWdfc2NoZW1hJTJGZGVmaW5pdGlvbnMlMkZwb3N0X2JyZWFjaF9hY3Rpb25zLnB5JTBBJTQwJTQwJTIwLTYyJTJDMTUlMjAlMkI2MiUyQzclMjAlNDAlNDAlMjBQT1NUX0JSRUFDSF9BQ1RJT05TJTIwJTNEJTIwJTdCJTBBJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIyUmVtb3ZlcyUyMHRoZSUyMGZpbGUlMjBhZnRlcndhcmRzLiUyMiUyQyUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMmF0dGFja190ZWNobmlxdWVzJTIyJTNBJTIwJTVCJTIyVDExNjYlMjIlNUQlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlN0QlMkMlMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTdCJTBBLSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMnR5cGUlMjIlM0ElMjAlMjJzdHJpbmclMjIlMkMlMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIyZW51bSUyMiUzQSUyMCU1QiUwQS0lMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjJTY2hlZHVsZUpvYnMlMjIlMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVEJTJDJTBBLSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMnRpdGxlJTIyJTNBJTIwJTIySm9iJTIwc2NoZWR1bGluZyUyMiUyQyUwQS0lMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjJpbmZvJTIyJTNBJTIwJTIyQXR0ZW1wdHMlMjB0byUyMGNyZWF0ZSUyMGElMjBzY2hlZHVsZWQlMjBqb2IlMjBvbiUyMHRoZSUyMHN5c3RlbSUyMGFuZCUyMHJlbW92ZSUyMGl0LiUyMiUyQyUwQS0lMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjJhdHRhY2tfdGVjaG5pcXVlcyUyMiUzQSUyMCU1QiUyMlQxMTY4JTIyJTJDJTIwJTIyVDEwNTMlMjIlNUQlMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTdEJTJDJTBBJTJCJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIzJTIwU3dpbW1lciUzQSUyMEFERCUyMERFVEFJTFMlMjBIRVJFISUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU3QiUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMnR5cGUlMjIlM0ElMjAlMjJzdHJpbmclMjIlMkMlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjJlbnVtJTIyJTNBJTIwJTVCJTBB", + "dod": "You should add your new PBA's details to the configuration.", + "description": "In order to make sure that the new `ScheduleJobs` PBA is shown in the configuration on the Monkey Island, you need to add its details to the configuration file(s).

\n\nSince this particular PBA is related to the MITRE techniques [T1168](https://attack.mitre.org/techniques/T1168) and [T1053](https://attack.mitre.org/techniques/T1053), make sure to link the PBA with these techniques in the configuration as well.

\n\nEach part of the configuration has an important role \n- *enum* — contains the relevant PBA's class name(s)\n- *title* — holds the name of the PBA which is displayed in the configuration on the Monkey Island\n- *info* — consists of an elaboration on the PBA's working which is displayed in the configuration on the Monkey Island\n- *attack_techniques* — has the IDs of the MITRE techniques associated with the PBA\n\n## Manual test \nOnce you think you're done...\n- Run the Monkey Island\n- You should be able to see your new PBA under the \"Monkey\" tab in the configuration, along with its information when you click on it\n- Further, when you enable/disable the associated MITRE techniques under the ATT&CK tab in the configuration, the PBA should also be enabled/disabled\n\n", + "summary": "- The PBA details in this file are reflected on the Monkey Island in the PBA configuration.\n- PBAs are also linked to the relevant MITRE techniques in this file, whose results can then be seen in the MITRE ATT&CK report on the Monkey Island.", + "diff": "diff --git a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py\nindex f1fe0f6f..cce37b24 100644\n--- a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py\n+++ b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py\n@@ -68,16 +68,7 @@\n \"Removes the file afterwards.\",\n \"attack_techniques\": [\"T1166\"]\n },\n- {\n+ # Swimmer: ADD DETAILS HERE!\n- \"type\": \"string\",\n- \"enum\": [\n- \"ScheduleJobs\"\n- ],\n- \"title\": \"Job scheduling\",\n- \"safe\": True,\n- \"info\": \"Attempts to create a scheduled job on the system and remove it.\",\n- \"attack_techniques\": [\"T1168\", \"T1053\"]\n- },\n {\n \"type\": \"string\",\n \"enum\": [\n", "tests": [], "hints": [ "Have a look at the details of the other techniques." ], - "files": { + "app_version": "0.3.2", + "file_version": "1.0.4", + "swimmPatch": { "monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py": { - "index": [ - "f1fe0f6f..cce37b24", - "100644" - ], - "fileA": "monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py", - "fileB": "monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py", - "status": "MODIFIED", - "numLineDeletions": 9, - "numLineAdditions": 1, - "hunkContainers": [ - "JTdCJTIyaHVuayUyMiUzQSU3QiUyMmhlYWRlciUyMiUzQSUyMiU0MCU0MCUyMC02MiUyQzE1JTIwJTJCNjIlMkM3JTIwJTQwJTQwJTIwUE9TVF9CUkVBQ0hfQUNUSU9OUyUyMCUzRCUyMCU3QiUyMiUyQyUyMmNoYW5nZXMlMjIlM0ElNUIlN0IlMjJ0eXBlJTIyJTNBJTIyY29udGV4dCUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlNUMlMjJSZW1vdmVzJTIwdGhlJTIwZmlsZSUyMGFmdGVyd2FyZHMuJTVDJTIyJTJDJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBNjIlMkMlMjJiJTIyJTNBNjIlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyY29udGV4dCUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlNUMlMjJhdHRhY2tfdGVjaG5pcXVlcyU1QyUyMiUzQSUyMCU1QiU1QyUyMlQxMTY2JTVDJTIyJTVEJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBNjMlMkMlMjJiJTIyJTNBNjMlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyY29udGV4dCUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlN0QlMkMlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0E2NCUyQyUyMmIlMjIlM0E2NCU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJkZWwlMjIlMkMlMjJtYXJrJTIyJTNBJTIyLSUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlN0IlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0E2NSU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJkZWwlMjIlMkMlMjJtYXJrJTIyJTNBJTIyLSUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlNUMlMjJ0eXBlJTVDJTIyJTNBJTIwJTVDJTIyc3RyaW5nJTVDJTIyJTJDJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBNjYlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyZGVsJTIyJTJDJTIybWFyayUyMiUzQSUyMi0lMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVDJTIyZW51bSU1QyUyMiUzQSUyMCU1QiUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTY3JTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QyUyMlNjaGVkdWxlSm9icyU1QyUyMiUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTY4JTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1RCUyQyUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTY5JTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QyUyMnRpdGxlJTVDJTIyJTNBJTIwJTVDJTIySm9iJTIwc2NoZWR1bGluZyU1QyUyMiUyQyUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTcwJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QyUyMmluZm8lNUMlMjIlM0ElMjAlNUMlMjJBdHRlbXB0cyUyMHRvJTIwY3JlYXRlJTIwYSUyMHNjaGVkdWxlZCUyMGpvYiUyMG9uJTIwdGhlJTIwc3lzdGVtJTIwYW5kJTIwcmVtb3ZlJTIwaXQuJTVDJTIyJTJDJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBNzElN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyZGVsJTIyJTJDJTIybWFyayUyMiUzQSUyMi0lMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVDJTIyYXR0YWNrX3RlY2huaXF1ZXMlNUMlMjIlM0ElMjAlNUIlNUMlMjJUMTE2OCU1QyUyMiUyQyUyMCU1QyUyMlQxMDUzJTVDJTIyJTVEJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBNzIlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyZGVsJTIyJTJDJTIybWFyayUyMiUzQSUyMi0lMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTdEJTJDJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBNzMlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyYWRkJTIyJTJDJTIybWFyayUyMiUzQSUyMiUyQiUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjMlMjBTd2ltbWVyJTNBJTIwQUREJTIwREVUQUlMUyUyMEhFUkUhJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJiJTIyJTNBNjUlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyY29udGV4dCUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlN0IlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0E3NCUyQyUyMmIlMjIlM0E2NiU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QyUyMnR5cGUlNUMlMjIlM0ElMjAlNUMlMjJzdHJpbmclNUMlMjIlMkMlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0E3NSUyQyUyMmIlMjIlM0E2NyU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QyUyMmVudW0lNUMlMjIlM0ElMjAlNUIlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0E3NiUyQyUyMmIlMjIlM0E2OCU3RCU3RCU1RCUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQSU3QiUyMnN0YXJ0TGluZSUyMiUzQTYyJTJDJTIybGluZXNDb3VudCUyMiUzQTE1JTdEJTJDJTIyYiUyMiUzQSU3QiUyMnN0YXJ0TGluZSUyMiUzQTYyJTJDJTIybGluZXNDb3VudCUyMiUzQTclN0QlN0QlN0QlN0Q=" + "diffType": "MODIFIED", + "fileDiffHeader": "diff --git a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py\nindex f1fe0f6f..cce37b24 100644\n--- a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py\n+++ b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py", + "hunks": [ + { + "swimmHunkMetadata": { + "hunkComments": [] + }, + "hunkDiffLines": [ + "@@ -68,16 +68,7 @@", + " \"Removes the file afterwards.\",", + " \"attack_techniques\": [\"T1166\"]", + " },", + "- {", + "+ # Swimmer: ADD DETAILS HERE!", + "- \"type\": \"string\",", + "- \"enum\": [", + "- \"ScheduleJobs\"", + "- ],", + "- \"title\": \"Job scheduling\",", + "- \"safe\": True,", + "- \"info\": \"Attempts to create a scheduled job on the system and remove it.\",", + "- \"attack_techniques\": [\"T1168\", \"T1053\"]", + "- },", + " {", + " \"type\": \"string\",", + " \"enum\": [" + ] + } ] } }, - "app_version": "0.1.90", - "file_version": "1.0.2" + "hunksOrder": [ + "monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py_0" + ], + "last_commit_sha_for_swimm_patch": "9d9e8168fb2c23367b9947273aa1a041687b3e2e" } \ No newline at end of file diff --git a/.swm/tbxb2cGgUiJQ8Btma0fp.swm b/.swm/tbxb2cGgUiJQ8Btma0fp.swm index e3be3fb14..e62725beb 100644 --- a/.swm/tbxb2cGgUiJQ8Btma0fp.swm +++ b/.swm/tbxb2cGgUiJQ8Btma0fp.swm @@ -1,75 +1,140 @@ { "id": "tbxb2cGgUiJQ8Btma0fp", "name": "Add a simple Post Breach action", - "dod": "WW91JTIwc2hvdWxkJTIwYWRkJTIwYSUyMG5ldyUyMFBCQSUyMHRvJTIwdGhlJTIwTW9ua2V5JTIwd2hpY2glMjBjcmVhdGVzJTIwYSUyMG5ldyUyMHVzZXIlMjBvbiUyMHRoZSUyMG1hY2hpbmUu", - "description": "UmVhZCUyMCU1Qm91ciUyMGRvY3VtZW50YXRpb24lMjBhYm91dCUyMGFkZGluZyUyMGElMjBuZXclMjBQQkElNUQoaHR0cHMlM0ElMkYlMkZ3d3cuZ3VhcmRpY29yZS5jb20lMkZpbmZlY3Rpb25tb25rZXklMkZkb2NzJTJGZGV2ZWxvcG1lbnQlMkZhZGRpbmctcG9zdC1icmVhY2gtYWN0aW9ucyUyRikuJTBBJTBBQWZ0ZXIlMjB0aGF0JTIwd2UlMjB3YW50JTIweW91JTIwdG8lMjBhZGQlMjB0aGUlMjBCYWNrZG9vclVzZXIlMjBQQkEuJTIwVGhlJTIwY29tbWFuZHMlMjB0aGF0JTIwYWRkJTIwdXNlcnMlMjBmb3IlMjBXaW4lMjBhbmQlMjBMaW51eCUyMGNhbiUyMGJlJTIwcmV0cmlldmVkJTIwZnJvbSUyMCU2MGdldF9jb21tYW5kc190b19hZGRfdXNlciU2MCUyMC0lMjBtYWtlJTIwc3VyZSUyMHlvdSUyMHNlZSUyMGhvdyUyMHRvJTIwdXNlJTIwdGhpcyUyMGZ1bmN0aW9uJTIwY29ycmVjdGx5LiUyMCUwQSUwQU5vdGUlMjB0aGF0JTIwdGhlJTIwUEJBJTIwc2hvdWxkJTIwaW1wYWN0JTIwdGhlJTIwVDExMzYlMjBNSVRSRSUyMHRlY2huaXF1ZSUyMGFzJTIwd2VsbCElMjAlMEElMEElMjMlMjBNYW51YWwlMjB0ZXN0JTIwdG8lMjBjb25maXJtJTBBJTBBMS4lMjBSdW4lMjB0aGUlMjBNb25rZXklMjBJc2xhbmQlMEEyLiUyME1ha2UlMjBzdXJlJTIweW91ciUyMG5ldyUyMFBCQSUyMGlzJTIwZW5hYmxlZCUyMGJ5JTIwZGVmYXVsdCUyMGluJTIwdGhlJTIwY29uZmlnJTIwLSUyMGZvciUyMHRoaXMlMjB0ZXN0JTJDJTIwZGlzYWJsZSUyMG5ldHdvcmslMjBzY2FubmluZyUyQyUyMGV4cGxvaXRpbmclMkMlMjBhbmQlMjBhbGwlMjBvdGhlciUyMFBCQXMlMEEzLiUyMFJ1biUyME1vbmtleSUwQTQuJTIwU2VlJTIwdGhlJTIwUEJBJTIwaW4lMjB0aGUlMjBzZWN1cml0eSUyMHJlcG9ydCUwQTUlMkMlMjBTZWUlMjB0aGUlMjBQQkElMjBpbiUyMHRoZSUyME1JVFJFJTIwcmVwb3J0JTIwaW4lMjB0aGUlMjByZWxldmFudCUyMHRlY2huaXF1ZSUwQQ==", - "summary": "VGFrZSUyMGElMjBsb29rJTIwYXQlMjB0aGUlMjBjb25maWd1cmF0aW9uJTIwb2YlMjB0aGUlMjBpc2xhbmQlMjBhZ2FpbiUyMC0lMjBzZWUlMjB0aGUlMjAlMjJjb21tYW5kJTIwdG8lMjBydW4lMjBhZnRlciUyMGJyZWFjaCUyMiUyMG9wdGlvbiUyMHdlJTIwb2ZmZXIlMjB0aGUlMjB1c2VyJTNGJTIwSXQncyUyMGltcGxlbWVudGVkJTIwZXhhY3RseSUyMGxpa2UlMjB5b3UlMjBkaWQlMjByaWdodCUyMG5vdyUyMGJ1dCUyMGVhY2glMjB1c2VyJTIwY2FuJTIwZG8lMjBpdCUyMGZvciUyMHRoZW1zZWx2ZXMuJTIwJTBBJTBBSG93ZXZlciUyQyUyMHdoYXQlMjBpZiUyMHRoZSUyMFBCQSUyMG5lZWRzJTIwdG8lMjBkbyUyMHN0dWZmJTIwd2hpY2glMjBpcyUyMG1vcmUlMjBjb21wbGV4JTIwdGhhbiUyMGp1c3QlMjBydW5uaW5nJTIwYSUyMGZldyUyMGNvbW1hbmRzJTNGJTIwSW4lMjB0aGF0JTIwY2FzZS4uLiUyMA==", - "diff": "ZGlmZiUyMC0tZ2l0JTIwYSUyRm1vbmtleSUyRmNvbW1vbiUyRmRhdGElMkZwb3N0X2JyZWFjaF9jb25zdHMucHklMjBiJTJGbW9ua2V5JTJGY29tbW9uJTJGZGF0YSUyRnBvc3RfYnJlYWNoX2NvbnN0cy5weSUwQWluZGV4JTIwYzNiYmE5OTUuLjAzMWY5YWQwJTIwMTAwNjQ0JTBBLS0tJTIwYSUyRm1vbmtleSUyRmNvbW1vbiUyRmRhdGElMkZwb3N0X2JyZWFjaF9jb25zdHMucHklMEElMkIlMkIlMkIlMjBiJTJGbW9ua2V5JTJGY29tbW9uJTJGZGF0YSUyRnBvc3RfYnJlYWNoX2NvbnN0cy5weSUwQSU0MCU0MCUyMC0xJTJDNSUyMCUyQjElMkM1JTIwJTQwJTQwJTBBJTIwUE9TVF9CUkVBQ0hfQ09NTVVOSUNBVEVfQVNfTkVXX1VTRVIlMjAlM0QlMjAlMjJDb21tdW5pY2F0ZSUyMGFzJTIwbmV3JTIwdXNlciUyMiUwQS1QT1NUX0JSRUFDSF9CQUNLRE9PUl9VU0VSJTIwJTNEJTIwJTIyQmFja2Rvb3IlMjB1c2VyJTIyJTBBJTJCJTIzJTIwU3dpbW1lciUzQSUyMFBVVCUyMFRIRSUyME5FVyUyMENPTlNUJTIwSEVSRSElMEElMjBQT1NUX0JSRUFDSF9GSUxFX0VYRUNVVElPTiUyMCUzRCUyMCUyMkZpbGUlMjBleGVjdXRpb24lMjIlMEElMjBQT1NUX0JSRUFDSF9TSEVMTF9TVEFSVFVQX0ZJTEVfTU9ESUZJQ0FUSU9OJTIwJTNEJTIwJTIyTW9kaWZ5JTIwc2hlbGwlMjBzdGFydHVwJTIwZmlsZSUyMiUwQSUyMFBPU1RfQlJFQUNIX0hJRERFTl9GSUxFUyUyMCUzRCUyMCUyMkhpZGUlMjBmaWxlcyUyMGFuZCUyMGRpcmVjdG9yaWVzJTIyJTBBZGlmZiUyMC0tZ2l0JTIwYSUyRm1vbmtleSUyRmluZmVjdGlvbl9tb25rZXklMkZwb3N0X2JyZWFjaCUyRmFjdGlvbnMlMkZhZGRfdXNlci5weSUyMGIlMkZtb25rZXklMkZpbmZlY3Rpb25fbW9ua2V5JTJGcG9zdF9icmVhY2glMkZhY3Rpb25zJTJGYWRkX3VzZXIucHklMEFpbmRleCUyMDU4YmU4OWExLi5kODQ3NmE5NyUyMDEwMDY0NCUwQS0tLSUyMGElMkZtb25rZXklMkZpbmZlY3Rpb25fbW9ua2V5JTJGcG9zdF9icmVhY2glMkZhY3Rpb25zJTJGYWRkX3VzZXIucHklMEElMkIlMkIlMkIlMjBiJTJGbW9ua2V5JTJGaW5mZWN0aW9uX21vbmtleSUyRnBvc3RfYnJlYWNoJTJGYWN0aW9ucyUyRmFkZF91c2VyLnB5JTBBJTQwJTQwJTIwLTElMkMxNSUyMCUyQjElMkM3JTIwJTQwJTQwJTBBLWZyb20lMjBjb21tb24uZGF0YS5wb3N0X2JyZWFjaF9jb25zdHMlMjBpbXBvcnQlMjBQT1NUX0JSRUFDSF9CQUNLRE9PUl9VU0VSJTBBLWZyb20lMjBpbmZlY3Rpb25fbW9ua2V5LmNvbmZpZyUyMGltcG9ydCUyMFdvcm1Db25maWd1cmF0aW9uJTBBJTIwZnJvbSUyMGluZmVjdGlvbl9tb25rZXkucG9zdF9icmVhY2gucGJhJTIwaW1wb3J0JTIwUEJBJTBBJTIwZnJvbSUyMGluZmVjdGlvbl9tb25rZXkudXRpbHMudXNlcnMlMjBpbXBvcnQlMjBnZXRfY29tbWFuZHNfdG9fYWRkX3VzZXIlMEElMjAlMEElMjAlMEElMjBjbGFzcyUyMEJhY2tkb29yVXNlcihQQkEpJTNBJTBBJTIwJTIwJTIwJTIwJTIwZGVmJTIwX19pbml0X18oc2VsZiklM0ElMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwbGludXhfY21kcyUyQyUyMHdpbmRvd3NfY21kcyUyMCUzRCUyMGdldF9jb21tYW5kc190b19hZGRfdXNlciglMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwV29ybUNvbmZpZ3VyYXRpb24udXNlcl90b19hZGQlMkMlMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwV29ybUNvbmZpZ3VyYXRpb24ucmVtb3RlX3VzZXJfcGFzcyklMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwc3VwZXIoQmFja2Rvb3JVc2VyJTJDJTIwc2VsZikuX19pbml0X18oJTBBLSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMFBPU1RfQlJFQUNIX0JBQ0tET09SX1VTRVIlMkMlMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwbGludXhfY21kJTNEJyUyMCcuam9pbihsaW51eF9jbWRzKSUyQyUwQS0lMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjB3aW5kb3dzX2NtZCUzRHdpbmRvd3NfY21kcyklMEElMkIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjBwYXNzJTIwJTIwJTIzJTIwU3dpbW1lciUzQSUyMEltcGwlMjBoZXJlISUwQWRpZmYlMjAtLWdpdCUyMGElMkZtb25rZXklMkZtb25rZXlfaXNsYW5kJTJGY2MlMkZzZXJ2aWNlcyUyRmF0dGFjayUyRnRlY2huaXF1ZV9yZXBvcnRzJTJGVDExMzYucHklMjBiJTJGbW9ua2V5JTJGbW9ua2V5X2lzbGFuZCUyRmNjJTJGc2VydmljZXMlMkZhdHRhY2slMkZ0ZWNobmlxdWVfcmVwb3J0cyUyRlQxMTM2LnB5JTBBaW5kZXglMjAwODZhMWMxMy4uZGE5OWU4NmMlMjAxMDA2NDQlMEEtLS0lMjBhJTJGbW9ua2V5JTJGbW9ua2V5X2lzbGFuZCUyRmNjJTJGc2VydmljZXMlMkZhdHRhY2slMkZ0ZWNobmlxdWVfcmVwb3J0cyUyRlQxMTM2LnB5JTBBJTJCJTJCJTJCJTIwYiUyRm1vbmtleSUyRm1vbmtleV9pc2xhbmQlMkZjYyUyRnNlcnZpY2VzJTJGYXR0YWNrJTJGdGVjaG5pcXVlX3JlcG9ydHMlMkZUMTEzNi5weSUwQSU0MCU0MCUyMC0xJTJDNSUyMCUyQjElMkM1JTIwJTQwJTQwJTBBJTIwZnJvbSUyMGNvbW1vbi5kYXRhLnBvc3RfYnJlYWNoX2NvbnN0cyUyMGltcG9ydCUyMCglMEEtJTIwJTIwJTIwJTIwUE9TVF9CUkVBQ0hfQkFDS0RPT1JfVVNFUiUyQyUyMFBPU1RfQlJFQUNIX0NPTU1VTklDQVRFX0FTX05FV19VU0VSKSUwQSUyQiUyMCUyMCUyMCUyMFBPU1RfQlJFQUNIX0NPTU1VTklDQVRFX0FTX05FV19VU0VSKSUwQSUyMGZyb20lMjBtb25rZXlfaXNsYW5kLmNjLnNlcnZpY2VzLmF0dGFjay50ZWNobmlxdWVfcmVwb3J0cy5wYmFfdGVjaG5pcXVlJTIwaW1wb3J0JTIwJTVDJTBBJTIwJTIwJTIwJTIwJTIwUG9zdEJyZWFjaFRlY2huaXF1ZSUwQSUyMCUwQSU0MCU0MCUyMC0xMSUyQzQlMjAlMkIxMSUyQzQlMjAlNDAlNDAlMjBjbGFzcyUyMFQxMTM2KFBvc3RCcmVhY2hUZWNobmlxdWUpJTNBJTBBJTIwJTIwJTIwJTIwJTIwdW5zY2FubmVkX21zZyUyMCUzRCUyMCUyMk1vbmtleSUyMGRpZG4ndCUyMHRyeSUyMGNyZWF0aW5nJTIwYSUyMG5ldyUyMHVzZXIlMjBvbiUyMHRoZSUyMG5ldHdvcmsncyUyMHN5c3RlbXMuJTIyJTBBJTIwJTIwJTIwJTIwJTIwc2Nhbm5lZF9tc2clMjAlM0QlMjAlMjJNb25rZXklMjB0cmllZCUyMGNyZWF0aW5nJTIwYSUyMG5ldyUyMHVzZXIlMjBvbiUyMHRoZSUyMG5ldHdvcmsncyUyMHN5c3RlbXMlMkMlMjBidXQlMjBmYWlsZWQuJTIyJTBBJTIwJTIwJTIwJTIwJTIwdXNlZF9tc2clMjAlM0QlMjAlMjJNb25rZXklMjBjcmVhdGVkJTIwYSUyMG5ldyUyMHVzZXIlMjBvbiUyMHRoZSUyMG5ldHdvcmsncyUyMHN5c3RlbXMuJTIyJTBBLSUyMCUyMCUyMCUyMHBiYV9uYW1lcyUyMCUzRCUyMCU1QlBPU1RfQlJFQUNIX0JBQ0tET09SX1VTRVIlMkMlMjBQT1NUX0JSRUFDSF9DT01NVU5JQ0FURV9BU19ORVdfVVNFUiU1RCUwQSUyQiUyMCUyMCUyMCUyMHBiYV9uYW1lcyUyMCUzRCUyMCU1QlBPU1RfQlJFQUNIX0NPTU1VTklDQVRFX0FTX05FV19VU0VSJTVEJTBBZGlmZiUyMC0tZ2l0JTIwYSUyRm1vbmtleSUyRm1vbmtleV9pc2xhbmQlMkZjYyUyRnNlcnZpY2VzJTJGY29uZmlnX3NjaGVtYSUyRmRlZmluaXRpb25zJTJGcG9zdF9icmVhY2hfYWN0aW9ucy5weSUyMGIlMkZtb25rZXklMkZtb25rZXlfaXNsYW5kJTJGY2MlMkZzZXJ2aWNlcyUyRmNvbmZpZ19zY2hlbWElMkZkZWZpbml0aW9ucyUyRnBvc3RfYnJlYWNoX2FjdGlvbnMucHklMEFpbmRleCUyMGYzZTJhOWJmLi4yYzRhYTY2NCUyMDEwMDY0NCUwQS0tLSUyMGElMkZtb25rZXklMkZtb25rZXlfaXNsYW5kJTJGY2MlMkZzZXJ2aWNlcyUyRmNvbmZpZ19zY2hlbWElMkZkZWZpbml0aW9ucyUyRnBvc3RfYnJlYWNoX2FjdGlvbnMucHklMEElMkIlMkIlMkIlMjBiJTJGbW9ua2V5JTJGbW9ua2V5X2lzbGFuZCUyRmNjJTJGc2VydmljZXMlMkZjb25maWdfc2NoZW1hJTJGZGVmaW5pdGlvbnMlMkZwb3N0X2JyZWFjaF9hY3Rpb25zLnB5JTBBJTQwJTQwJTIwLTQlMkMxNSUyMCUyQjQlMkM3JTIwJTQwJTQwJTIwUE9TVF9CUkVBQ0hfQUNUSU9OUyUyMCUzRCUyMCU3QiUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMm1pZ2h0JTIwZG8lMjBhZnRlciUyMGJyZWFjaGluZyUyMGElMjBuZXclMjBtYWNoaW5lLiUyMFVzZWQlMjBpbiUyMEFUVCUyNkNLJTIwYW5kJTIwWmVybyUyMHRydXN0JTIwcmVwb3J0cy4lMjIlMkMlMEElMjAlMjAlMjAlMjAlMjAlMjJ0eXBlJTIyJTNBJTIwJTIyc3RyaW5nJTIyJTJDJTBBJTIwJTIwJTIwJTIwJTIwJTIyYW55T2YlMjIlM0ElMjAlNUIlMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTdCJTBBLSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMnR5cGUlMjIlM0ElMjAlMjJzdHJpbmclMjIlMkMlMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIyZW51bSUyMiUzQSUyMCU1QiUwQS0lMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjJCYWNrZG9vclVzZXIlMjIlMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVEJTJDJTBBLSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMnRpdGxlJTIyJTNBJTIwJTIyQmFjayUyMGRvb3IlMjB1c2VyJTIyJTJDJTBBLSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMmluZm8lMjIlM0ElMjAlMjJBdHRlbXB0cyUyMHRvJTIwY3JlYXRlJTIwYSUyMG5ldyUyMHVzZXIlMjBvbiUyMHRoZSUyMHN5c3RlbSUyMGFuZCUyMGRlbGV0ZSUyMGl0JTIwYWZ0ZXJ3YXJkcy4lMjIlMkMlMEEtJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIyYXR0YWNrX3RlY2huaXF1ZXMlMjIlM0ElMjAlNUIlMjJUMTEzNiUyMiU1RCUwQS0lMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlN0QlMkMlMEElMkIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjMlMjBTd2ltbWVyJTNBJTIwQWRkJTIwbmV3JTIwUEJBJTIwaGVyZSUyMHRvJTIwY29uZmlnISUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU3QiUwQSUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMnR5cGUlMjIlM0ElMjAlMjJzdHJpbmclMjIlMkMlMEElMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjJlbnVtJTIyJTNBJTIwJTVCJTBB", + "dod": "You should add a new PBA to the Monkey which creates a new user on the machine.", + "description": "Read [our documentation about adding a new PBA](https://www.guardicore.com/infectionmonkey/docs/development/adding-post-breach-actions/).\n\nAfter that we want you to add the BackdoorUser PBA. The commands that add users for Win and Linux can be retrieved from `get_commands_to_add_user` - make sure you see how to use this function correctly. \n\nNote that the PBA should impact the T1136 MITRE technique as well! \n\n# Manual test to confirm\n\n1. Run the Monkey Island\n2. Make sure your new PBA is enabled by default in the config - for this test, disable network scanning, exploiting, and all other PBAs\n3. Run Monkey\n4. See the PBA in the security report\n5, See the PBA in the MITRE report in the relevant technique\n", + "summary": "Take a look at the configuration of the island again - see the \"command to run after breach\" option we offer the user? It's implemented exactly like you did right now but each user can do it for themselves. \n\nHowever, what if the PBA needs to do stuff which is more complex than just running a few commands? In that case... ", + "diff": "diff --git a/monkey/common/data/post_breach_consts.py b/monkey/common/data/post_breach_consts.py\nindex c3bba995..031f9ad0 100644\n--- a/monkey/common/data/post_breach_consts.py\n+++ b/monkey/common/data/post_breach_consts.py\n@@ -1,5 +1,5 @@\n POST_BREACH_COMMUNICATE_AS_NEW_USER = \"Communicate as new user\"\n-POST_BREACH_BACKDOOR_USER = \"Backdoor user\"\n+# Swimmer: PUT THE NEW CONST HERE!\n POST_BREACH_FILE_EXECUTION = \"File execution\"\n POST_BREACH_SHELL_STARTUP_FILE_MODIFICATION = \"Modify shell startup file\"\n POST_BREACH_HIDDEN_FILES = \"Hide files and directories\"\ndiff --git a/monkey/infection_monkey/post_breach/actions/add_user.py b/monkey/infection_monkey/post_breach/actions/add_user.py\nindex 58be89a1..d8476a97 100644\n--- a/monkey/infection_monkey/post_breach/actions/add_user.py\n+++ b/monkey/infection_monkey/post_breach/actions/add_user.py\n@@ -1,15 +1,7 @@\n-from common.data.post_breach_consts import POST_BREACH_BACKDOOR_USER\n-from infection_monkey.config import WormConfiguration\n from infection_monkey.post_breach.pba import PBA\n from infection_monkey.utils.users import get_commands_to_add_user\n \n \n class BackdoorUser(PBA):\n def __init__(self):\n- linux_cmds, windows_cmds = get_commands_to_add_user(\n+ pass # Swimmer: Impl here!\n- WormConfiguration.user_to_add,\n- WormConfiguration.remote_user_pass)\n- super(BackdoorUser, self).__init__(\n- POST_BREACH_BACKDOOR_USER,\n- linux_cmd=' '.join(linux_cmds),\n- windows_cmd=windows_cmds)\ndiff --git a/monkey/monkey_island/cc/services/attack/technique_reports/T1136.py b/monkey/monkey_island/cc/services/attack/technique_reports/T1136.py\nindex 086a1c13..da99e86c 100644\n--- a/monkey/monkey_island/cc/services/attack/technique_reports/T1136.py\n+++ b/monkey/monkey_island/cc/services/attack/technique_reports/T1136.py\n@@ -1,5 +1,5 @@\n from common.data.post_breach_consts import (\n- POST_BREACH_BACKDOOR_USER, POST_BREACH_COMMUNICATE_AS_NEW_USER)\n+ POST_BREACH_COMMUNICATE_AS_NEW_USER)\n from monkey_island.cc.services.attack.technique_reports.pba_technique import \\\n PostBreachTechnique\n \n@@ -11,4 +11,4 @@\n unscanned_msg = \"Monkey didn't try creating a new user on the network's systems.\"\n scanned_msg = \"Monkey tried creating a new user on the network's systems, but failed.\"\n used_msg = \"Monkey created a new user on the network's systems.\"\n- pba_names = [POST_BREACH_BACKDOOR_USER, POST_BREACH_COMMUNICATE_AS_NEW_USER]\n+ pba_names = [POST_BREACH_COMMUNICATE_AS_NEW_USER]\ndiff --git a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py\nindex f3e2a9bf..2c4aa664 100644\n--- a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py\n+++ b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py\n@@ -4,16 +4,7 @@\n \"might do after breaching a new machine. Used in ATT&CK and Zero trust reports.\",\n \"type\": \"string\",\n \"anyOf\": [\n- {\n+ # Swimmer: Add new PBA here to config!\n- \"type\": \"string\",\n- \"enum\": [\n- \"BackdoorUser\"\n- ],\n- \"title\": \"Back door user\",\n- \"safe\": True,\n- \"info\": \"Attempts to create a new user on the system and delete it afterwards.\",\n- \"attack_techniques\": [\"T1136\"]\n- },\n {\n \"type\": \"string\",\n \"enum\": [\n", "tests": [], "hints": [ "See `ScheduleJobs` PBA for an example of a PBA which only uses shell commands.", "Make sure to add the PBA to the configuration as well.", "MITRE ATT&CK technique T1136 articulates that adversaries may create an account to maintain access to victim systems, therefore, the BackdoorUser PBA is relevant to it. Make sure to map this PBA to the MITRE ATT&CK configuration and report." ], - "files": { + "app_version": "0.3.2", + "file_version": "1.0.4", + "swimmPatch": { "monkey/common/data/post_breach_consts.py": { - "index": [ - "c3bba995..031f9ad0", - "100644" - ], - "fileA": "monkey/common/data/post_breach_consts.py", - "fileB": "monkey/common/data/post_breach_consts.py", - "status": "MODIFIED", - "numLineDeletions": 1, - "numLineAdditions": 1, - "hunkContainers": [ - "JTdCJTIyaHVuayUyMiUzQSU3QiUyMmhlYWRlciUyMiUzQSUyMiU0MCU0MCUyMC0xJTJDNSUyMCUyQjElMkM1JTIwJTQwJTQwJTIyJTJDJTIyY2hhbmdlcyUyMiUzQSU1QiU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMFBPU1RfQlJFQUNIX0NPTU1VTklDQVRFX0FTX05FV19VU0VSJTIwJTNEJTIwJTVDJTIyQ29tbXVuaWNhdGUlMjBhcyUyMG5ldyUyMHVzZXIlNUMlMjIlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExJTJDJTIyYiUyMiUzQTElN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyZGVsJTIyJTJDJTIybWFyayUyMiUzQSUyMi0lMjIlMkMlMjJkYXRhJTIyJTNBJTIyUE9TVF9CUkVBQ0hfQkFDS0RPT1JfVVNFUiUyMCUzRCUyMCU1QyUyMkJhY2tkb29yJTIwdXNlciU1QyUyMiUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTIlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyYWRkJTIyJTJDJTIybWFyayUyMiUzQSUyMiUyQiUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjMlMjBTd2ltbWVyJTNBJTIwUFVUJTIwVEhFJTIwTkVXJTIwQ09OU1QlMjBIRVJFISUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYiUyMiUzQTIlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyY29udGV4dCUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjBQT1NUX0JSRUFDSF9GSUxFX0VYRUNVVElPTiUyMCUzRCUyMCU1QyUyMkZpbGUlMjBleGVjdXRpb24lNUMlMjIlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0EzJTJDJTIyYiUyMiUzQTMlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyY29udGV4dCUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjBQT1NUX0JSRUFDSF9TSEVMTF9TVEFSVFVQX0ZJTEVfTU9ESUZJQ0FUSU9OJTIwJTNEJTIwJTVDJTIyTW9kaWZ5JTIwc2hlbGwlMjBzdGFydHVwJTIwZmlsZSU1QyUyMiUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTQlMkMlMjJiJTIyJTNBNCU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMFBPU1RfQlJFQUNIX0hJRERFTl9GSUxFUyUyMCUzRCUyMCU1QyUyMkhpZGUlMjBmaWxlcyUyMGFuZCUyMGRpcmVjdG9yaWVzJTVDJTIyJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBNSUyQyUyMmIlMjIlM0E1JTdEJTdEJTVEJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBJTdCJTIyc3RhcnRMaW5lJTIyJTNBMSUyQyUyMmxpbmVzQ291bnQlMjIlM0E1JTdEJTJDJTIyYiUyMiUzQSU3QiUyMnN0YXJ0TGluZSUyMiUzQTElMkMlMjJsaW5lc0NvdW50JTIyJTNBNSU3RCU3RCU3RCU3RA==" + "diffType": "MODIFIED", + "fileDiffHeader": "diff --git a/monkey/common/data/post_breach_consts.py b/monkey/common/data/post_breach_consts.py\nindex c3bba995..031f9ad0 100644\n--- a/monkey/common/data/post_breach_consts.py\n+++ b/monkey/common/data/post_breach_consts.py", + "hunks": [ + { + "swimmHunkMetadata": { + "hunkComments": [] + }, + "hunkDiffLines": [ + "@@ -1,5 +1,5 @@", + " POST_BREACH_COMMUNICATE_AS_NEW_USER = \"Communicate as new user\"", + "-POST_BREACH_BACKDOOR_USER = \"Backdoor user\"", + "+# Swimmer: PUT THE NEW CONST HERE!", + " POST_BREACH_FILE_EXECUTION = \"File execution\"", + " POST_BREACH_SHELL_STARTUP_FILE_MODIFICATION = \"Modify shell startup file\"", + " POST_BREACH_HIDDEN_FILES = \"Hide files and directories\"" + ] + } ] }, "monkey/infection_monkey/post_breach/actions/add_user.py": { - "index": [ - "58be89a1..d8476a97", - "100644" - ], - "fileA": "monkey/infection_monkey/post_breach/actions/add_user.py", - "fileB": "monkey/infection_monkey/post_breach/actions/add_user.py", - "status": "MODIFIED", - "numLineDeletions": 9, - "numLineAdditions": 1, - "hunkContainers": [ - "JTdCJTIyaHVuayUyMiUzQSU3QiUyMmhlYWRlciUyMiUzQSUyMiU0MCU0MCUyMC0xJTJDMTUlMjAlMkIxJTJDNyUyMCU0MCU0MCUyMiUyQyUyMmNoYW5nZXMlMjIlM0ElNUIlN0IlMjJ0eXBlJTIyJTNBJTIyZGVsJTIyJTJDJTIybWFyayUyMiUzQSUyMi0lMjIlMkMlMjJkYXRhJTIyJTNBJTIyZnJvbSUyMGNvbW1vbi5kYXRhLnBvc3RfYnJlYWNoX2NvbnN0cyUyMGltcG9ydCUyMFBPU1RfQlJFQUNIX0JBQ0tET09SX1VTRVIlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMmZyb20lMjBpbmZlY3Rpb25fbW9ua2V5LmNvbmZpZyUyMGltcG9ydCUyMFdvcm1Db25maWd1cmF0aW9uJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBMiU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMGZyb20lMjBpbmZlY3Rpb25fbW9ua2V5LnBvc3RfYnJlYWNoLnBiYSUyMGltcG9ydCUyMFBCQSUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTMlMkMlMjJiJTIyJTNBMSU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMGZyb20lMjBpbmZlY3Rpb25fbW9ua2V5LnV0aWxzLnVzZXJzJTIwaW1wb3J0JTIwZ2V0X2NvbW1hbmRzX3RvX2FkZF91c2VyJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBNCUyQyUyMmIlMjIlM0EyJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmNvbnRleHQlMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBNSUyQyUyMmIlMjIlM0EzJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmNvbnRleHQlMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBNiUyQyUyMmIlMjIlM0E0JTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmNvbnRleHQlMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwY2xhc3MlMjBCYWNrZG9vclVzZXIoUEJBKSUzQSUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTclMkMlMjJiJTIyJTNBNSU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMGRlZiUyMF9faW5pdF9fKHNlbGYpJTNBJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBOCUyQyUyMmIlMjIlM0E2JTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMGxpbnV4X2NtZHMlMkMlMjB3aW5kb3dzX2NtZHMlMjAlM0QlMjBnZXRfY29tbWFuZHNfdG9fYWRkX3VzZXIoJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBOSU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJkZWwlMjIlMkMlMjJtYXJrJTIyJTNBJTIyLSUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjBXb3JtQ29uZmlndXJhdGlvbi51c2VyX3RvX2FkZCUyQyUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTEwJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMFdvcm1Db25maWd1cmF0aW9uLnJlbW90ZV91c2VyX3Bhc3MpJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBMTElN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyZGVsJTIyJTJDJTIybWFyayUyMiUzQSUyMi0lMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwc3VwZXIoQmFja2Rvb3JVc2VyJTJDJTIwc2VsZikuX19pbml0X18oJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBMTIlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyZGVsJTIyJTJDJTIybWFyayUyMiUzQSUyMi0lMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwUE9TVF9CUkVBQ0hfQkFDS0RPT1JfVVNFUiUyQyUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTEzJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMGxpbnV4X2NtZCUzRCclMjAnLmpvaW4obGludXhfY21kcyklMkMlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExNCU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJkZWwlMjIlMkMlMjJtYXJrJTIyJTNBJTIyLSUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjB3aW5kb3dzX2NtZCUzRHdpbmRvd3NfY21kcyklMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExNSU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJhZGQlMjIlMkMlMjJtYXJrJTIyJTNBJTIyJTJCJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMHBhc3MlMjAlMjAlMjMlMjBTd2ltbWVyJTNBJTIwSW1wbCUyMGhlcmUhJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJiJTIyJTNBNyU3RCU3RCU1RCUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQSU3QiUyMnN0YXJ0TGluZSUyMiUzQTElMkMlMjJsaW5lc0NvdW50JTIyJTNBMTUlN0QlMkMlMjJiJTIyJTNBJTdCJTIyc3RhcnRMaW5lJTIyJTNBMSUyQyUyMmxpbmVzQ291bnQlMjIlM0E3JTdEJTdEJTdEJTdE" + "diffType": "MODIFIED", + "fileDiffHeader": "diff --git a/monkey/infection_monkey/post_breach/actions/add_user.py b/monkey/infection_monkey/post_breach/actions/add_user.py\nindex 58be89a1..d8476a97 100644\n--- a/monkey/infection_monkey/post_breach/actions/add_user.py\n+++ b/monkey/infection_monkey/post_breach/actions/add_user.py", + "hunks": [ + { + "swimmHunkMetadata": { + "hunkComments": [] + }, + "hunkDiffLines": [ + "@@ -1,15 +1,7 @@", + "-from common.data.post_breach_consts import POST_BREACH_BACKDOOR_USER", + "-from infection_monkey.config import WormConfiguration", + " from infection_monkey.post_breach.pba import PBA", + " from infection_monkey.utils.users import get_commands_to_add_user", + " ", + " ", + " class BackdoorUser(PBA):", + " def __init__(self):", + "- linux_cmds, windows_cmds = get_commands_to_add_user(", + "+ pass # Swimmer: Impl here!", + "- WormConfiguration.user_to_add,", + "- WormConfiguration.remote_user_pass)", + "- super(BackdoorUser, self).__init__(", + "- POST_BREACH_BACKDOOR_USER,", + "- linux_cmd=' '.join(linux_cmds),", + "- windows_cmd=windows_cmds)" + ] + } ] }, "monkey/monkey_island/cc/services/attack/technique_reports/T1136.py": { - "index": [ - "086a1c13..da99e86c", - "100644" - ], - "fileA": "monkey/monkey_island/cc/services/attack/technique_reports/T1136.py", - "fileB": "monkey/monkey_island/cc/services/attack/technique_reports/T1136.py", - "status": "MODIFIED", - "numLineDeletions": 2, - "numLineAdditions": 2, - "hunkContainers": [ - "JTdCJTIyaHVuayUyMiUzQSU3QiUyMmhlYWRlciUyMiUzQSUyMiU0MCU0MCUyMC0xJTJDNSUyMCUyQjElMkM1JTIwJTQwJTQwJTIyJTJDJTIyY2hhbmdlcyUyMiUzQSU1QiU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMGZyb20lMjBjb21tb24uZGF0YS5wb3N0X2JyZWFjaF9jb25zdHMlMjBpbXBvcnQlMjAoJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBMSUyQyUyMmIlMjIlM0ExJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMFBPU1RfQlJFQUNIX0JBQ0tET09SX1VTRVIlMkMlMjBQT1NUX0JSRUFDSF9DT01NVU5JQ0FURV9BU19ORVdfVVNFUiklMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0EyJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmFkZCUyMiUyQyUyMm1hcmslMjIlM0ElMjIlMkIlMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwUE9TVF9CUkVBQ0hfQ09NTVVOSUNBVEVfQVNfTkVXX1VTRVIpJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJiJTIyJTNBMiU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMGZyb20lMjBtb25rZXlfaXNsYW5kLmNjLnNlcnZpY2VzLmF0dGFjay50ZWNobmlxdWVfcmVwb3J0cy5wYmFfdGVjaG5pcXVlJTIwaW1wb3J0JTIwJTVDJTVDJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBMyUyQyUyMmIlMjIlM0EzJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmNvbnRleHQlMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwUG9zdEJyZWFjaFRlY2huaXF1ZSUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTQlMkMlMjJiJTIyJTNBNCU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTUlMkMlMjJiJTIyJTNBNSU3RCU3RCU1RCUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQSU3QiUyMnN0YXJ0TGluZSUyMiUzQTElMkMlMjJsaW5lc0NvdW50JTIyJTNBNSU3RCUyQyUyMmIlMjIlM0ElN0IlMjJzdGFydExpbmUlMjIlM0ExJTJDJTIybGluZXNDb3VudCUyMiUzQTUlN0QlN0QlN0QlN0Q=", - "JTdCJTIyaHVuayUyMiUzQSU3QiUyMmhlYWRlciUyMiUzQSUyMiU0MCU0MCUyMC0xMSUyQzQlMjAlMkIxMSUyQzQlMjAlNDAlNDAlMjBjbGFzcyUyMFQxMTM2KFBvc3RCcmVhY2hUZWNobmlxdWUpJTNBJTIyJTJDJTIyY2hhbmdlcyUyMiUzQSU1QiU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMHVuc2Nhbm5lZF9tc2clMjAlM0QlMjAlNUMlMjJNb25rZXklMjBkaWRuJ3QlMjB0cnklMjBjcmVhdGluZyUyMGElMjBuZXclMjB1c2VyJTIwb24lMjB0aGUlMjBuZXR3b3JrJ3MlMjBzeXN0ZW1zLiU1QyUyMiUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTExJTJDJTIyYiUyMiUzQTExJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmNvbnRleHQlMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwc2Nhbm5lZF9tc2clMjAlM0QlMjAlNUMlMjJNb25rZXklMjB0cmllZCUyMGNyZWF0aW5nJTIwYSUyMG5ldyUyMHVzZXIlMjBvbiUyMHRoZSUyMG5ldHdvcmsncyUyMHN5c3RlbXMlMkMlMjBidXQlMjBmYWlsZWQuJTVDJTIyJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBMTIlMkMlMjJiJTIyJTNBMTIlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyY29udGV4dCUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjB1c2VkX21zZyUyMCUzRCUyMCU1QyUyMk1vbmtleSUyMGNyZWF0ZWQlMjBhJTIwbmV3JTIwdXNlciUyMG9uJTIwdGhlJTIwbmV0d29yaydzJTIwc3lzdGVtcy4lNUMlMjIlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExMyUyQyUyMmIlMjIlM0ExMyU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJkZWwlMjIlMkMlMjJtYXJrJTIyJTNBJTIyLSUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjBwYmFfbmFtZXMlMjAlM0QlMjAlNUJQT1NUX0JSRUFDSF9CQUNLRE9PUl9VU0VSJTJDJTIwUE9TVF9CUkVBQ0hfQ09NTVVOSUNBVEVfQVNfTkVXX1VTRVIlNUQlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExNCU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJhZGQlMjIlMkMlMjJtYXJrJTIyJTNBJTIyJTJCJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMHBiYV9uYW1lcyUyMCUzRCUyMCU1QlBPU1RfQlJFQUNIX0NPTU1VTklDQVRFX0FTX05FV19VU0VSJTVEJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJiJTIyJTNBMTQlN0QlN0QlNUQlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ElN0IlMjJzdGFydExpbmUlMjIlM0ExMSUyQyUyMmxpbmVzQ291bnQlMjIlM0E0JTdEJTJDJTIyYiUyMiUzQSU3QiUyMnN0YXJ0TGluZSUyMiUzQTExJTJDJTIybGluZXNDb3VudCUyMiUzQTQlN0QlN0QlN0QlN0Q=" + "diffType": "MODIFIED", + "fileDiffHeader": "diff --git a/monkey/monkey_island/cc/services/attack/technique_reports/T1136.py b/monkey/monkey_island/cc/services/attack/technique_reports/T1136.py\nindex 086a1c13..da99e86c 100644\n--- a/monkey/monkey_island/cc/services/attack/technique_reports/T1136.py\n+++ b/monkey/monkey_island/cc/services/attack/technique_reports/T1136.py", + "hunks": [ + { + "swimmHunkMetadata": { + "hunkComments": [] + }, + "hunkDiffLines": [ + "@@ -1,5 +1,5 @@", + " from common.data.post_breach_consts import (", + "- POST_BREACH_BACKDOOR_USER, POST_BREACH_COMMUNICATE_AS_NEW_USER)", + "+ POST_BREACH_COMMUNICATE_AS_NEW_USER)", + " from monkey_island.cc.services.attack.technique_reports.pba_technique import \\", + " PostBreachTechnique", + " " + ] + }, + { + "swimmHunkMetadata": { + "hunkComments": [] + }, + "hunkDiffLines": [ + "@@ -11,4 +11,4 @@", + " unscanned_msg = \"Monkey didn't try creating a new user on the network's systems.\"", + " scanned_msg = \"Monkey tried creating a new user on the network's systems, but failed.\"", + " used_msg = \"Monkey created a new user on the network's systems.\"", + "- pba_names = [POST_BREACH_BACKDOOR_USER, POST_BREACH_COMMUNICATE_AS_NEW_USER]", + "+ pba_names = [POST_BREACH_COMMUNICATE_AS_NEW_USER]" + ] + } ] }, "monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py": { - "index": [ - "f3e2a9bf..2c4aa664", - "100644" - ], - "fileA": "monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py", - "fileB": "monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py", - "status": "MODIFIED", - "numLineDeletions": 9, - "numLineAdditions": 1, - "hunkContainers": [ - "JTdCJTIyaHVuayUyMiUzQSU3QiUyMmhlYWRlciUyMiUzQSUyMiU0MCU0MCUyMC00JTJDMTUlMjAlMkI0JTJDNyUyMCU0MCU0MCUyMFBPU1RfQlJFQUNIX0FDVElPTlMlMjAlM0QlMjAlN0IlMjIlMkMlMjJjaGFuZ2VzJTIyJTNBJTVCJTdCJTIydHlwZSUyMiUzQSUyMmNvbnRleHQlMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVDJTIybWlnaHQlMjBkbyUyMGFmdGVyJTIwYnJlYWNoaW5nJTIwYSUyMG5ldyUyMG1hY2hpbmUuJTIwVXNlZCUyMGluJTIwQVRUJTI2Q0slMjBhbmQlMjBaZXJvJTIwdHJ1c3QlMjByZXBvcnRzLiU1QyUyMiUyQyUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTQlMkMlMjJiJTIyJTNBNCU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCU1QyUyMnR5cGUlNUMlMjIlM0ElMjAlNUMlMjJzdHJpbmclNUMlMjIlMkMlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0E1JTJDJTIyYiUyMiUzQTUlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyY29udGV4dCUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlNUMlMjJhbnlPZiU1QyUyMiUzQSUyMCU1QiUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTYlMkMlMjJiJTIyJTNBNiU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJkZWwlMjIlMkMlMjJtYXJrJTIyJTNBJTIyLSUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlN0IlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0E3JTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QyUyMnR5cGUlNUMlMjIlM0ElMjAlNUMlMjJzdHJpbmclNUMlMjIlMkMlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0E4JTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QyUyMmVudW0lNUMlMjIlM0ElMjAlNUIlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0E5JTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QyUyMkJhY2tkb29yVXNlciU1QyUyMiUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTEwJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1RCUyQyUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTExJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QyUyMnRpdGxlJTVDJTIyJTNBJTIwJTVDJTIyQmFjayUyMGRvb3IlMjB1c2VyJTVDJTIyJTJDJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBMTIlN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyZGVsJTIyJTJDJTIybWFyayUyMiUzQSUyMi0lMjIlMkMlMjJkYXRhJTIyJTNBJTIyJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTIwJTVDJTIyaW5mbyU1QyUyMiUzQSUyMCU1QyUyMkF0dGVtcHRzJTIwdG8lMjBjcmVhdGUlMjBhJTIwbmV3JTIwdXNlciUyMG9uJTIwdGhlJTIwc3lzdGVtJTIwYW5kJTIwZGVsZXRlJTIwaXQlMjBhZnRlcndhcmRzLiU1QyUyMiUyQyUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTEzJTdEJTdEJTJDJTdCJTIydHlwZSUyMiUzQSUyMmRlbCUyMiUyQyUyMm1hcmslMjIlM0ElMjItJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QyUyMmF0dGFja190ZWNobmlxdWVzJTVDJTIyJTNBJTIwJTVCJTVDJTIyVDExMzYlNUMlMjIlNUQlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExNCU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJkZWwlMjIlMkMlMjJtYXJrJTIyJTNBJTIyLSUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlN0QlMkMlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExNSU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJhZGQlMjIlMkMlMjJtYXJrJTIyJTNBJTIyJTJCJTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMyUyMFN3aW1tZXIlM0ElMjBBZGQlMjBuZXclMjBQQkElMjBoZXJlJTIwdG8lMjBjb25maWchJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJiJTIyJTNBNyU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU3QiUyMiUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQTE2JTJDJTIyYiUyMiUzQTglN0QlN0QlMkMlN0IlMjJ0eXBlJTIyJTNBJTIyY29udGV4dCUyMiUyQyUyMmRhdGElMjIlM0ElMjIlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlMjAlNUMlMjJ0eXBlJTVDJTIyJTNBJTIwJTVDJTIyc3RyaW5nJTVDJTIyJTJDJTIyJTJDJTIybGluZU51bWJlcnMlMjIlM0ElN0IlMjJhJTIyJTNBMTclMkMlMjJiJTIyJTNBOSU3RCU3RCUyQyU3QiUyMnR5cGUlMjIlM0ElMjJjb250ZXh0JTIyJTJDJTIyZGF0YSUyMiUzQSUyMiUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCUyMCU1QyUyMmVudW0lNUMlMjIlM0ElMjAlNUIlMjIlMkMlMjJsaW5lTnVtYmVycyUyMiUzQSU3QiUyMmElMjIlM0ExOCUyQyUyMmIlMjIlM0ExMCU3RCU3RCU1RCUyQyUyMmxpbmVOdW1iZXJzJTIyJTNBJTdCJTIyYSUyMiUzQSU3QiUyMnN0YXJ0TGluZSUyMiUzQTQlMkMlMjJsaW5lc0NvdW50JTIyJTNBMTUlN0QlMkMlMjJiJTIyJTNBJTdCJTIyc3RhcnRMaW5lJTIyJTNBNCUyQyUyMmxpbmVzQ291bnQlMjIlM0E3JTdEJTdEJTdEJTdE" + "diffType": "MODIFIED", + "fileDiffHeader": "diff --git a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py\nindex f3e2a9bf..2c4aa664 100644\n--- a/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py\n+++ b/monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py", + "hunks": [ + { + "swimmHunkMetadata": { + "hunkComments": [] + }, + "hunkDiffLines": [ + "@@ -4,16 +4,7 @@", + " \"might do after breaching a new machine. Used in ATT&CK and Zero trust reports.\",", + " \"type\": \"string\",", + " \"anyOf\": [", + "- {", + "+ # Swimmer: Add new PBA here to config!", + "- \"type\": \"string\",", + "- \"enum\": [", + "- \"BackdoorUser\"", + "- ],", + "- \"title\": \"Back door user\",", + "- \"safe\": True,", + "- \"info\": \"Attempts to create a new user on the system and delete it afterwards.\",", + "- \"attack_techniques\": [\"T1136\"]", + "- },", + " {", + " \"type\": \"string\",", + " \"enum\": [" + ] + } ] } }, - "app_version": "0.1.90", - "file_version": "1.0.2" + "hunksOrder": [ + "monkey/common/data/post_breach_consts.py_0", + "monkey/infection_monkey/post_breach/actions/add_user.py_0", + "monkey/monkey_island/cc/services/attack/technique_reports/T1136.py_0", + "monkey/monkey_island/cc/services/attack/technique_reports/T1136.py_1", + "monkey/monkey_island/cc/services/config_schema/definitions/post_breach_actions.py_0" + ], + "last_commit_sha_for_swimm_patch": "9d9e8168fb2c23367b9947273aa1a041687b3e2e" } \ No newline at end of file