DynamicLabs: Windows & Active Directory Exploitation
DynamicLabs
If you are after red-team training, there are multiple excellent courses and online resources for practicing adversary simulation. That’s not the primary motivation behind Alfa labs.
Alfa labs allows:
– Blue/red teamers to test or demonstrate specific attacks/attack-paths (e.g. when GMSA edges were introduced into BloodHound).
– Beginners to take a structured approach to learn Active Directory weaknesses (which have largely been practically accessible if you build your own lab, during workshops w/ limited spaces or commercial training).
– Replicate any technical issues and confirm your results
Therefore, stop by and spin up your own lab to practice your Windows Active Directory tools, techniques, and procedures (TTPs) in isolation, or red-team your way through the dynamically-built Alfa labs.
Setup
- Download the project from https://github.com/ctxis/DynamicLabs.
- Download Terraform v0.12.
- Install Terraform into your system path or /bin appropriately.
- Also, copy the Terraform Linux x64 binary to “/dynamic-labs/Terraform/Azure/Core/Canonical/Ubuntu/18.04_Management/files/”.
- Generate a pair of SSH keys and place them into “~/dynamic-labs/SSH-Keys/”. Ensure that other users cannot read your SSH key.
- Download a 3rd party provider for dynamic Ansible inventory generation from https://github.com/nbering/terraform-provider-ansible/releases/tag/v1.0.3. Place the binary into “%APPDATA%\terraform.d\plugins” on Windows or “~/.terraform.d/plugins” on Linux. E.g. AppData\Roaming\terraform.d\plugins\windows_amd64\terraform-provider-ansible_v1.0.3.exe
Deployment Instructions for AWS
- Ensure that your current directory is set to dynamic labs.
- Create a new terraform workspace. terraform workspace new <name>
- Initiate Terraform modules. terraform init ./Terraform/AWS/
- Copy “./Templates///terrfaorm-AWS.tfvars.example” to “./Templates///terrfaorm-AWS.tfvars”
- Edit the new file to add in your Azure connection details, your network range, and SSH key names.
- Begin deployment. terraform apply -auto-approve -var-file=”./Templates/<type>/<name>/terraform-aws.tfvars” ./Terraform/AWS/
- Send over the Terraform state file to your management server. scp -r -i ./SSH-Keys/<mgmnt_key> ./terraform.tfstate.d/<workspace name>/terraform.tfstate ubuntu@<mgmnt_box_ip>:~/
- SSH onto the management server and kick-off resource configuration.
ssh -i ./SSH-Keys/<mgmnt_key> ubuntu@<mgmnt_box_ip> #> ansible-playbook -i /etc/ansible/terraform.py ./Ansible/site.yml -vvvv
Copyright 2020 Context Information Security – Rohan (@Decode141)