Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/uber-common/metta
An information security preparedness tool to do adversarial simulation.
https://github.com/uber-common/metta
adversarial celery infosec network networking python redis security simulation uber vagrant virtualbox yaml
Last synced: 26 days ago
JSON representation
An information security preparedness tool to do adversarial simulation.
- Host: GitHub
- URL: https://github.com/uber-common/metta
- Owner: uber-common
- License: mit
- Created: 2017-11-01T21:24:47.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2019-04-01T06:34:25.000Z (over 5 years ago)
- Last Synced: 2024-09-30T23:01:32.056Z (about 1 month ago)
- Topics: adversarial, celery, infosec, network, networking, python, redis, security, simulation, uber, vagrant, virtualbox, yaml
- Language: Python
- Size: 523 KB
- Stars: 1,092
- Watchers: 75
- Forks: 151
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-incident-response - Metta - Information security preparedness tool to do adversarial simulation. (IR tools Collection / Adversary Emulation)
- awesome-incident-response - Metta - Information security preparedness tool to do adversarial simulation. (IR Tools Collection / Adversary Emulation)
- awesome-mitre-attack - Metta - An information security preparedness tool to do adversarial simulation. (Red and Purple Team / Tools)
- fucking-awesome-incident-response - Metta - Information security preparedness tool to do adversarial simulation. (IR Tools Collection / Adversary Emulation)
README
# Metta
Metta is an information security preparedness tool.
This project uses Redis/Celery, python, and vagrant with virtualbox to do adversarial simulation. This allows you to test (mostly) your host based instrumentation but may also allow you to test any network based detection and controls depending on how you set up your vagrants.
The project parses yaml files with actions and uses celery to queue these actions up and run them one at a time without interaction.
---
# Installation
[see setup.md](setup.md)There is also a [wiki](https://github.com/uber-common/metta/wiki)
# Running actions
The various actions live in the MITRE folder sorted by MITRE ATT&CK phases and also in Adversarial_SimulationJust run the python and yaml file of your choice
```
$ python run_simulation_yaml.py -f MITRE/Discovery/discovery_win_account.yml
YAML FILE: MITRE/Discovery/discovery_account.yaml
OS matched windows...sending to the windows vagrant
Running: cmd.exe /c net group \"Domain Admins\" /domain
Running: cmd.exe /c net user /add
Running: cmd.exe /c net user /domain
Running: cmd.exe /c net localgroup administrators
Running: cmd.exe /c net share
Running: cmd.exe /c net use
Running: cmd.exe /c net accounts
Running: cmd.exe /c net config workstation
Running: cmd.exe /c dsquery server
Running: cmd.exe /c dsquery user -name smith* | dsget user -dn -desc
Running: cmd.exe /c wmic useraccount list /format:list
Running: cmd.exe /c wmic ntdomain
Running: cmd.exe /c wmic group list /format:list
Running: cmd.exe /c wmic sysaccount list /format:list
```# Making actions
The actions and scenarios live in the MITRE folder sorted by MITRE ATT&CK phases and also in Adversarial_Simulation
![actions example](docs/images/scenario.png)The most important parts are the OS field and the purple_actions
os: will tell the tool which vagrant to send the command to, obviously *nix commands on windows wont work out so well
purple_actions: an array of commands to run sequentially
# Making scenarios
Scenarios are a list of paths to actions.The code will be looking for a scenario: True field and scenario_actions list. Example below:
![scenario example](docs/images/scenario2.png)# Gotchas
The tool takes the string from purple_actions and encapsulates it in quotes. Therefore you need to escape any other quotes, ticks, weird shell characters in your command.
Use the output of the vagrant/celery piece to make sure things are working like they should
# Why Metta?
Metta (Pali)
Loving kindness, gentle friendship; a practice for generating loving kindness said to be first taught by the Buddha as an antidote to fear. It helps cultivate our natural capacity for an open and loving heart and is traditionally offered along with other Brahma-vihara meditations that enrich compassion, joy in the happiness of others and equanimity. These practices lead to the development of concentration, fearlessness, happiness and a greater ability to love.