PrintNightmare
PRACTICE ! PRACTICE ! PRACTICE !
Last updated
PRACTICE ! PRACTICE ! PRACTICE !
Last updated
According to Microsoft, PrintNightmare is a remote code execution vulnerability exists when the Windows Print Spooler service improperly performs privileged file operations. An attacker who successfully exploited this vulnerability could run arbitrary code with SYSTEM privileges. An attacker could then install programs; view, change, or delete data; or create new accounts with full user rights"
Microsoft defines the Print spooler service as a service that runs on each computer system
The Print spooler service manages the printing processes - The Print spooler's responsibilities are managing the print jobs, receiving files to be printed, queueing them, and scheduling
Remember the early days when users had to wait for print jobs to finish to perform other operations? Well, the Print spooler service took care of this issue for us - It is also important to note that the Print spooler service is enabled by default in all Windows clients and servers
Domain Controllers mainly use Print spooler service for Printer Pruning (the process of removing the printers that are not in use anymore on the network and have been added as objects to Active Directory) - Printer Pruning eliminates the issue for the users reaching out to a non-existent printer
As per Microsoft, To exploit the CVE-2021-1675 vulnerability, the attacker would need to have direct or local access to the machine to use a malicious DLL file to escalate privileges
Meanhile, To exploit the CVE-2021-34527 vulnerability successfully, the attacker can remotely inject the malicious DLL file
It can be exploited over the network; the attacker doesn't need direct access to the machine.
The proof-of-concept was made public on the Internet.
The Print Spooler service is enabled by DEFAULT on domain controllers and computers with SYSTEM privileges
Let's first check if the DC is vulnerable to PrintNightmare exploit, to do this let's dump the rpc info
Okay its vulnerbale, Now create a malicious.dll
using msfvenom, and then host a smbserver on that directory and run the exploit
Let's run the exploit now and observer we get a reverse shell on our listener !
And BOOM!, we have a reverse shell on our listener as SYSTEM PRIVILEGES :)
Disable Print Spooler's Service - is appropriate for your environment
Disable inbound remote printing throught group policy
Remember that for the group policy to take effect across the domain, or even the local machine, you need to issue a
gpupdate /force
command