Added "-s" flag for setup-only, useful for building Islands

This commit is contained in:
Shay Nehmad 2020-03-31 20:15:34 +03:00
parent 950e160627
commit 224861d084
3 changed files with 26 additions and 4 deletions

View File

@ -1,4 +1,16 @@
from monkey_island.cc.main import main from monkey_island.cc.main import main
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.")
args = parser.parse_args()
return args.setup_only
if "__main__" == __name__: if "__main__" == __name__:
main() is_setup_only = parse_cli_args()
main(is_setup_only)

View File

@ -29,7 +29,7 @@ from common.version import get_version
from monkey_island.cc.setup import setup from monkey_island.cc.setup import setup
def main(): def main(should_setup_only):
from tornado.wsgi import WSGIContainer from tornado.wsgi import WSGIContainer
from tornado.httpserver import HTTPServer from tornado.httpserver import HTTPServer
from tornado.ioloop import IOLoop from tornado.ioloop import IOLoop
@ -46,6 +46,10 @@ def main():
setup() setup()
if should_setup_only:
logger.warning("Setup only flag passed. Exiting.")
return
if env.is_debug(): if env.is_debug():
app.run(host='0.0.0.0', debug=True, ssl_context=(crt_path, key_path)) app.run(host='0.0.0.0', debug=True, ssl_context=(crt_path, key_path))
else: else:

View File

@ -1,10 +1,16 @@
import logging
from monkey_island.cc.services.attack.mitre_api_interface import MitreApiInterface from monkey_island.cc.services.attack.mitre_api_interface import MitreApiInterface
from cc.models.attack.attack_mitigations import AttackMitigations from monkey_island.cc.models.attack.attack_mitigations import AttackMitigations
from monkey_island.cc.database import mongo from monkey_island.cc.database import mongo
from pymongo import errors from pymongo import errors
logger = logging.getLogger(__name__)
def setup(): def setup():
logger.info("Setting up the Monkey Island, this might take a while...")
try_store_mitigations_on_mongo() try_store_mitigations_on_mongo()
@ -13,7 +19,7 @@ def try_store_mitigations_on_mongo():
try: try:
mongo.db.validate_collection(mitigation_collection_name) mongo.db.validate_collection(mitigation_collection_name)
if mongo.db.attack_mitigations.count() == 0: if mongo.db.attack_mitigations.count() == 0:
raise errors.OperationFailure("Mitigation collection empty") raise errors.OperationFailure("Mitigation collection empty. Try dropping the collection and running again")
except errors.OperationFailure: except errors.OperationFailure:
try: try:
mongo.db.create_collection(mitigation_collection_name) mongo.db.create_collection(mitigation_collection_name)