Powerview or SharpView (.NET equivalent)
- Get it from here and put it in the compromised machine 
- From a cmd in the target: - powershell -ep bypass
- Launch Powerview: - . .\powerview.ps1
- Get info on the Domain Controller: - Get-NetDomain
- Check policies: - Get-DomainPolicy
- Policies in System Access: - (Get-DomainPolicy)."systemAccess"(e.g.: we get info about password policy and minimum length so min size if we want to password spray)
- Info about the users - Get-NetUser
- Get only usenames - Get-NetUser | select cn(e.g.: will output Jessica Jones)
- Get only sam account name: - Get-NetUser | select samaccountname(e.g.: will output jjones)
- Get only description: - Get-NetUser | select description(e.g.: will output a description if provided by sysadmn or a default one)
- See all the properties a user have: - Get-UserProperty
- Get more details for example password last set: - Get-UserProperty -Properties pwdlastset
- Get more details for example logoncount: - Get-UserProperty -Properties logoncount
- See if users have entered bad passwd: - Get-UserProperty -Properties badpwdcount
- List all the computers in the Domain: - Get-NetComputer
- Same but with much more info: - Get-NetComputer -FullData
- Filter this load of data with specific info: - Get-NetComputer -FullData | select OperatingSystem
- Get info on groups: - Get-NetGroup
- Filter for a specific GroupName: - Get-NetGroup -GroupName "Domain Admins"
- Filter on GroupName with a wildcard: - Get-NetGroup -GroupName *admin*
- Get users from a specific group: - Get-NetGroup -GroupName "Domain Admins"
- Get smb shared in the network: - Invoke-ShareFinder
- Get group policies: - Get-NetGPO
- Filter the info: - Get-NetGroup -GroupName "Domain Admins"
- .\SharpView.exe ConvertTo-SID -Name first.lastFind SID of a user
- .\SharpView.exe Convert-ADName -ObjectName SIDfind user with SID
- Get-DomainPolicyView the domain password policy (will show passwordhistorysize)
- Get-DomainUser first.last \| ConvertFrom-UACValue -showallList all UAC values
- .\SharpView.exe Get-DomainView information about the current domain
- .\SharpView.exe Get-DomainOUList all OUs
- .\SharpView.exe Get-DomainUser -KerberosPreauthNotRequiredFind ASREPRoastable users
- Get-DomainComputerGet a listing of domain computers
- .\SharpView.exe Get-DomainGPO \| findstr displaynameList all GPO names
- Get-DomainGPO -ComputerIdentity HOSTNAMEList GPOs on a specific host
- Test-AdminAccess -ComputerName HOSTNAMETest local admin access on a remote host
- .\SharpView.exe Get-NetShare -ComputerName HOSTNAMEEnumerate open shares on a remote computer
- Find-DomainUserLocationFind machines where domain users are logged in
- Get-DomainTrustView a list of domain trusts
- (Get-DomainUser).countCount all domain users
- .\SharpView.exe Get-DomainUser -HelpGet help about a SharpView function
- Get-DomainUser -Properties samaccountname,description \| Where {$_.description -ne $null}Find non-blank user description fields
- .\SharpView.exe Get-DomainUser -SPNFind users with SPNs set
- Find-ForeignGroupFind foreign domain users
- Get-DomainGroup -Properties NameList domain groups
- .\SharpView.exe Get-DomainGroupMember -Identity 'Help Desk'Get members of a domain group
- .\SharpView.exe Get-DomainGroup -AdminCountList protected groups
- .\SharpView.exe Find-ManagedSecurityGroupsList managed security groups
- Get-NetLocalGroup -ComputerName HOSTGet local groups on a host
- .\SharpView.exe Get-NetLocalGroupMember -ComputerName HOSTNAMEGet members of a local group
- .\SharpView.exe Get-DomainComputer -UnconstrainedFind computers that allow unconstrained delegation
- Get-DomainComputer -TrustedToAuthFind computers set with constrained delegation
- Get-DomainObjectAcl -Identity first.lastEnumerate ACLs on a user
- Find-InterestingDomainAclFind objects in the domain with modification rights over non built-in objects
- Get-PathAcl "\\HOSTNAME\Directory"Find the ACLs set on a directory
- gpresult /r /S HOSTNAMEGet a report of all GPOs applied to a host
- Get-DomainGPO \| Get-ObjectAclFind GPO permissions
- Get-DomainTrustMappingEnumerate trusts for our domain/reachable domains
- Get-NetShare -ComputerName COMPUTERList share on computer
- Get-DomainGPOlist all gpo and related info
- Get-DomainGPO | select displaynamelist all gpo names
- Get-DomainGPO | select displayname,objectguidlist gpo names with their guid
- Get-DomainTrustMappingenumerate all trusts for our current domain and other reachable domains
- Get-NetDomainsimilar to the ActiveDirectory module’s Get-ADDomain but contains a lot less information. Basic info such as the Forest, Domain Controllers, and Domain Name are enumerated.
- Get-NetDomainControllerlist all of the Domain Controllers within the network
- Get-NetForestsimilar to Get-ADForest, and provides similar output. It provides all the associated Domains, the root domain, as well as the Domain Controllers for the root domain.
- Get-NetDomainTrustis similar to Get-ADTrust with our SelectObject filter applied to it.
Enumerating Users
- get-netuserwill output all infos about users in the domain
- get-netuser | select cnwill list all users
- get-netuser | select -expandproperty samaccountnamewill list users but only samccountname
- find-userfield -SearchField description "password"will list description fields of users with a grep on "password"
Enumerating Groups
- get-netgroupwill list all the different groups in the domain
- get-netgroup -Username "f.lastname"will show group of user f.lastname
- get-netgroup -GroupName "domain admins" -FullDatawill show details of the group
Enumerating Domain Computers and Shares
- Get-NetComputer -OperatingSystem "*Windows 10*"Get computer with Win 10 OS
- Get-NetComputer -OperatingSystem "*server*"Get the server
- Invoke-ShareFinderwill list shares
- Invoke-ShareFinder -ExcludeStandard -ExcludePrint -ExcludeIPCwill list sharw without standard print and IPC
Find interesting files
- Invoke-FileFinder
Enumerate Local Admin Users
- Invoke-EnumerateLocalAdmin
Enumerating Group Policy Objects
- get-netgpo
Enumerating Access Control Lists
- get-objectacl
- get-objectacl -SamAccountName "name" -ResolveGUIDs
Enumerating the domain
- get-netdomain
- Get-DomainPolicy
- Get-domainsiduseful for golden tickets
Note: If you do not get result with powerview, you can try this in powershell Import-Module .\PowerView.ps1
Powerview - Resources
Last updated
