-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscenario_builder.py
More file actions
executable file
·45 lines (38 loc) · 2.52 KB
/
scenario_builder.py
File metadata and controls
executable file
·45 lines (38 loc) · 2.52 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#!/usr/bin/python
from scenario_builder.utils import setup_custom_logger
import argparse
from scenario_builder import manager
parser = argparse.ArgumentParser(description='Forensic Scenario Builder CLI')
parser.add_argument('--bot', required=True, nargs=1, help='Location of file describing bot container or vm.')
parser.add_argument('--bot-num', nargs=1, type=int, default=[1], help='Number of bot containers to spawn. Defaults to one.')
parser.add_argument('--attacker', required=True, nargs=1, help='Location of file describing attacker container or vm.')
parser.add_argument('--attacker-ip', nargs=1, default=['random'], help='Assign static ip to attacker. Defaults to random assignment.')
parser.add_argument('--victim', required=True, nargs=1, help='Location of file describing victim container or vm.')
parser.add_argument('--victim-ip', nargs=1, default=['random'], help='Assign static ip to victim. Defaults to random assignment.')
parser.add_argument('--time-out', nargs=1, type=int, default=[5], help='Number of minutes to run scenario. Defaults to 5 minutes.')
parser.add_argument('--logs', nargs='?', const='/var/log/', help='Location to pull log file(s) from on victim after scenario is done. Defaults to /var/log.')
parser.add_argument('--disk-image', nargs='?', const='./filesystem.image.gz', help='Create disk image of victim after scenario is done')
parser.add_argument('--memory-dump', nargs='?', const='./mem-image.lime', help='Create memory dump of victim after scenario is done')
parser.add_argument('--pcap', nargs='?', const='./capture.pcap', help='Create packet capture of scenario traffic')
parser.add_argument('--subnet', default='10.0.0.0/8', help='Subnet to place scenarios and containers on. Defaults to 10.0.0.0/8')
args = parser.parse_args()
arg_dict = {}
arg_dict['bot'] = {'dir': args.bot[0],
'num-ips': args.bot_num[0],
'manager': 'docker'}
arg_dict['attacker'] = {'dir': args.attacker[0],
'ip': args.attacker_ip[0],
'manager': 'docker'}
arg_dict['victim'] = {'dir': args.victim[0],
'ip': args.victim_ip[0],
'manager': 'vagrant'}
arg_dict['subnet'] = args.subnet
arg_dict['pcap'] = args.pcap
arg_dict['disk_image'] = args.disk_image
arg_dict['logs'] = args.logs
arg_dict['mem_dump'] = args.memory_dump
arg_dict['timeout'] = args.time_out[0]
logger = setup_custom_logger('root')
logger.debug('Starting up scenario builder')
logger.debug('Argument Dictionary: {}'.format(arg_dict))
manager.run_scenario(arg_dict)