dcFinder is basic python script that detects domain controllers in forest enviroinment using scapy module and DNS SRV records. In addition to detect hostname of domain controller, you can find Primary DC that is included in a specific site.
Query types: site, primarydc, globalcatalogdc, nonglobalcatalogdc, kerberos
SRV Records: _ldap._tcp.<SiteName>._sites.dc.<DNSDomainName> _ldap._tcp.pdc._msdcs.<DNSDomainName> _ldap._tcp.gc._msdcs.<DNSDomainName> _ldap._tcp.dc._msdcs.<DNSDomainName> _kerberos._tcp.dc._msdcs.<DNSDomainName> Use globalcatalogdc option to detect DCs in the Forest. Example : python3 dcFinder.py --lookup --domain offensive.local --query globalcatalogdc Use nonglobalcatalogdc option to check if there are Domain Controller(s) non-global catalog or not. Example : python3 dcFinder.py --lookup --domain offensive.local --query nonglobalcatalogdc Use site option to detect DC in the site. Example : python3 dcFinder.py --lookup --domain offensive.local --query site --sitename gotham Use kerberos option, if you have issue with ldap srv query for finding domain controller. Example : python3 dcFinder.py --lookup --domain offensive.local --query kerberos Please, install current development version of scapy firstly.
git clone https://github.com/secdev/scapy.git cd scapy sudo python setup.py install Install following modules after above installation process.
argparse sys colorama