Home

Awesome

WSUSpect Proxy

Written by Paul Stone and Alex Chapman, Context Information Security

Summary

This is a proof of concept script to inject 'fake' updates into non-SSL WSUS traffic. It is based on our BlackHat USA 2015 presentation, 'WSUSpect – Compromising the Windows Enterprise via Windows Update'

Prerequisites

You'll need the Python Twisted library installed. You can do this by running:

pip install twisted

You also need to place a Microsoft-signed binary (e.g. PsExec) into the payloads directory. This script has been tested on Python 2.7. It does not yet work with Python 3.x; contributions are welcome.

Usage

To test this out, you'll need a target Windows 7 or 8 machine that is configured to receive updates from a WSUS server over unencrypted HTTP. The machine should be configured to proxy through the machine running this script. This can be done by manually changing the proxy settings or via other means such as WPAD poisoning (e.g. using Responder)

python wsuspect_proxy.py payload_name [port]

An example payload for PsExec is set up that will launch cmd.exe running as Administrator:

python wsuspect_proxy.py psexec

If you are having problems getting the script to work we'd recommend using a GUI proxy tool such as Burp (and configuring Burp to use this script as a proxy) to see if the update XML is being correctly inserted.

Customisation

Modify payloads/payloads.ini to change the payloads and their arguments.

Known Issues

Screenshots

WSUSpect in action

WSUSpect script output